patch 9.1.1440: too many strlen() calls in os_win32.c
Problem: too many strlen() calls in os_win32.c
Solution: refactor code and remove calls to strlen()
(John Marriott)
The following changes have been made:
- In mch_init_g():
- refactor to remove calls to STRLEN().
- use vim_strnsave() instead of vim_strsave().
- set a flag if vimrun_path is stored in allocated memory so it can be
freed at exit.
- In mch_exit() free vimrun_path if it was stored in allocated memory.
- In fname_case() make a small optimisation by measuring the length of
name only if needed.
- In copy_extattr() make a small optimisation by replacing call to
STRCAT() with STRCPY().
closes: #17462
Signed-off-by: John Marriott <basilisk@internode.on.net>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
3fa0d3514b
commit
9cb27a57c8
@ -164,7 +164,8 @@ static int write_input_record_buffer(INPUT_RECORD* irEvents, int nLength);
|
|||||||
#ifdef FEAT_GUI_MSWIN
|
#ifdef FEAT_GUI_MSWIN
|
||||||
static int s_dont_use_vimrun = TRUE;
|
static int s_dont_use_vimrun = TRUE;
|
||||||
static int need_vimrun_warning = FALSE;
|
static int need_vimrun_warning = FALSE;
|
||||||
static char *vimrun_path = "vimrun ";
|
static string_T vimrun_path = {(char_u *)"vimrun ", 7};
|
||||||
|
static int vimrun_path_allocated = FALSE;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int win32_getattrs(char_u *name);
|
static int win32_getattrs(char_u *name);
|
||||||
@ -3019,37 +3020,58 @@ mch_init_g(void)
|
|||||||
Rows = 25;
|
Rows = 25;
|
||||||
Columns = 80;
|
Columns = 80;
|
||||||
|
|
||||||
// Look for 'vimrun'
|
// Look for 'vimrun'.
|
||||||
{
|
{
|
||||||
char_u vimrun_location[_MAX_PATH + 4];
|
char_u vimrun_location[_MAX_PATH + 4];
|
||||||
|
size_t exe_pathlen = (size_t)(gettail(exe_name) - exe_name);
|
||||||
|
|
||||||
// First try in same directory as gvim.exe
|
// Note: 10 is length of 'vimrun.exe'.
|
||||||
STRCPY(vimrun_location, exe_name);
|
if (exe_pathlen + 10 >= sizeof(vimrun_location))
|
||||||
STRCPY(gettail(vimrun_location), "vimrun.exe");
|
|
||||||
if (mch_getperm(vimrun_location) >= 0)
|
|
||||||
{
|
{
|
||||||
char *p;
|
if (executable_exists("vimrun.exe", NULL, TRUE, FALSE))
|
||||||
|
s_dont_use_vimrun = FALSE;
|
||||||
if (*skiptowhite(vimrun_location) != NUL)
|
|
||||||
{
|
|
||||||
// Enclose path with white space in double quotes.
|
|
||||||
mch_memmove(vimrun_location + 1, vimrun_location,
|
|
||||||
STRLEN(vimrun_location) + 1);
|
|
||||||
*vimrun_location = '"';
|
|
||||||
STRCPY(gettail(vimrun_location), "vimrun\" ");
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
STRCPY(gettail(vimrun_location), "vimrun ");
|
{
|
||||||
|
// First try in same directory as gvim.exe.
|
||||||
|
if (exe_pathlen > 0)
|
||||||
|
vim_strncpy(vimrun_location, exe_name, exe_pathlen);
|
||||||
|
STRCPY(vimrun_location + exe_pathlen, "vimrun.exe");
|
||||||
|
|
||||||
p = (char *)vim_strsave(vimrun_location);
|
if (mch_getperm(vimrun_location) >= 0)
|
||||||
|
{
|
||||||
|
char_u *p;
|
||||||
|
size_t plen;
|
||||||
|
|
||||||
|
if (exe_pathlen > 0 && *skiptowhite(vimrun_location) != NUL)
|
||||||
|
{
|
||||||
|
// Enclose path with white space in double quotes.
|
||||||
|
plen = vim_snprintf_safelen(
|
||||||
|
(char *)vimrun_location,
|
||||||
|
sizeof(vimrun_location),
|
||||||
|
"\"%.*svimrun\" ",
|
||||||
|
(int)exe_pathlen, exe_name);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Remove the suffix ('.exe').
|
||||||
|
vimrun_location[exe_pathlen + 6] = ' ';
|
||||||
|
vimrun_location[exe_pathlen + 7] = NUL;
|
||||||
|
plen = exe_pathlen + 7;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = vim_strnsave(vimrun_location, plen);
|
||||||
if (p != NULL)
|
if (p != NULL)
|
||||||
{
|
{
|
||||||
vimrun_path = p;
|
vimrun_path.string = p;
|
||||||
|
vimrun_path.length = plen;
|
||||||
|
vimrun_path_allocated = TRUE;
|
||||||
s_dont_use_vimrun = FALSE;
|
s_dont_use_vimrun = FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (executable_exists("vimrun.exe", NULL, TRUE, FALSE))
|
else if (executable_exists("vimrun.exe", NULL, TRUE, FALSE))
|
||||||
s_dont_use_vimrun = FALSE;
|
s_dont_use_vimrun = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
// Don't give the warning for a missing vimrun.exe right now, but only
|
// Don't give the warning for a missing vimrun.exe right now, but only
|
||||||
// when vimrun was supposed to be used. Don't bother people that do
|
// when vimrun was supposed to be used. Don't bother people that do
|
||||||
@ -3059,7 +3081,7 @@ mch_init_g(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If "finstr.exe" doesn't exist, use "grep -n" for 'grepprg'.
|
* If "findstr.exe" doesn't exist, use "grep -n" for 'grepprg'.
|
||||||
* Otherwise the default "findstr /n" is used.
|
* Otherwise the default "findstr /n" is used.
|
||||||
*/
|
*/
|
||||||
if (!executable_exists("findstr.exe", NULL, TRUE, FALSE))
|
if (!executable_exists("findstr.exe", NULL, TRUE, FALSE))
|
||||||
@ -3652,11 +3674,16 @@ mch_exit(int r)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef VIMDLL
|
#ifdef VIMDLL
|
||||||
|
if (vimrun_path_allocated)
|
||||||
|
vim_free(vimrun_path.string);
|
||||||
|
|
||||||
if (gui.in_use || gui.starting)
|
if (gui.in_use || gui.starting)
|
||||||
mch_exit_g(r);
|
mch_exit_g(r);
|
||||||
else
|
else
|
||||||
mch_exit_c(r);
|
mch_exit_c(r);
|
||||||
#elif defined(FEAT_GUI_MSWIN)
|
#elif defined(FEAT_GUI_MSWIN)
|
||||||
|
if (vimrun_path_allocated)
|
||||||
|
vim_free(vimrun_path.string);
|
||||||
mch_exit_g(r);
|
mch_exit_g(r);
|
||||||
#else
|
#else
|
||||||
mch_exit_c(r);
|
mch_exit_c(r);
|
||||||
@ -3695,12 +3722,10 @@ fname_case(
|
|||||||
char_u *name,
|
char_u *name,
|
||||||
int len)
|
int len)
|
||||||
{
|
{
|
||||||
int flen;
|
|
||||||
WCHAR *p;
|
WCHAR *p;
|
||||||
WCHAR buf[_MAX_PATH + 1];
|
WCHAR buf[_MAX_PATH + 1];
|
||||||
|
|
||||||
flen = (int)STRLEN(name);
|
if (*name == NUL)
|
||||||
if (flen == 0)
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
slash_adjust(name);
|
slash_adjust(name);
|
||||||
@ -3715,8 +3740,15 @@ fname_case(
|
|||||||
|
|
||||||
if (q != NULL)
|
if (q != NULL)
|
||||||
{
|
{
|
||||||
if (len > 0 || flen >= (int)STRLEN(q))
|
if (len > 0)
|
||||||
vim_strncpy(name, q, (len > 0) ? len - 1 : flen);
|
vim_strncpy(name, q, len - 1);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
size_t namelen = STRLEN(name);
|
||||||
|
if (namelen >= STRLEN(q))
|
||||||
|
vim_strncpy(name, q, namelen);
|
||||||
|
}
|
||||||
|
|
||||||
vim_free(q);
|
vim_free(q);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -5678,7 +5710,7 @@ mch_call_shell(
|
|||||||
#ifdef FEAT_GUI_MSWIN
|
#ifdef FEAT_GUI_MSWIN
|
||||||
((gui.in_use || gui.starting) ?
|
((gui.in_use || gui.starting) ?
|
||||||
(!s_dont_use_vimrun && p_stmp ?
|
(!s_dont_use_vimrun && p_stmp ?
|
||||||
STRLEN(vimrun_path) : STRLEN(p_sh) + STRLEN(p_shcf))
|
vimrun_path.length : STRLEN(p_sh) + STRLEN(p_shcf))
|
||||||
: 0) +
|
: 0) +
|
||||||
#endif
|
#endif
|
||||||
STRLEN(p_sh) + STRLEN(p_shcf) + STRLEN(cmd) + 10;
|
STRLEN(p_sh) + STRLEN(p_shcf) + STRLEN(cmd) + 10;
|
||||||
@ -5714,7 +5746,7 @@ mch_call_shell(
|
|||||||
// Use vimrun to execute the command. It opens a console
|
// Use vimrun to execute the command. It opens a console
|
||||||
// window, which can be closed without killing Vim.
|
// window, which can be closed without killing Vim.
|
||||||
vim_snprintf((char *)newcmd, cmdlen, "%s%s%s %s %s",
|
vim_snprintf((char *)newcmd, cmdlen, "%s%s%s %s %s",
|
||||||
vimrun_path,
|
vimrun_path.string,
|
||||||
(msg_silent != 0 || (options & SHELL_DOOUT))
|
(msg_silent != 0 || (options & SHELL_DOOUT))
|
||||||
? "-s " : "",
|
? "-s " : "",
|
||||||
p_sh, p_shcf, cmd);
|
p_sh, p_shcf, cmd);
|
||||||
@ -8111,9 +8143,9 @@ copy_extattr(char_u *from, char_u *to)
|
|||||||
if (fromf == NULL || tof == NULL)
|
if (fromf == NULL || tof == NULL)
|
||||||
goto theend;
|
goto theend;
|
||||||
STRCPY(fromf, "\\??\\");
|
STRCPY(fromf, "\\??\\");
|
||||||
STRCAT(fromf, from);
|
STRCPY(fromf + STRLEN_LITERAL("\\??\\"), from);
|
||||||
STRCPY(tof, "\\??\\");
|
STRCPY(tof, "\\??\\");
|
||||||
STRCAT(tof, to);
|
STRCPY(tof + STRLEN_LITERAL("\\??\\"), to);
|
||||||
|
|
||||||
// Convert the names to wide characters.
|
// Convert the names to wide characters.
|
||||||
fromw = enc_to_utf16(fromf, NULL);
|
fromw = enc_to_utf16(fromf, NULL);
|
||||||
|
|||||||
@ -709,6 +709,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1440,
|
||||||
/**/
|
/**/
|
||||||
1439,
|
1439,
|
||||||
/**/
|
/**/
|
||||||
|
|||||||
Reference in New Issue
Block a user