Problem: MS-Windows uninstall may delete wrong batch file.
Solution: Add specific marker in the generated batch file. (Ken Takata,
closes #5654)
$(OUTDIR):
if not exist $(OUTDIR)/nul mkdir $(OUTDIR)
-CFLAGS_INST = /nologo -DNDEBUG -DWIN32 -DWINVER=$(WINVER) -D_WIN32_WINNT=$(WINVER) $(CFLAGS_DEPR)
+CFLAGS_INST = /nologo /O2 -DNDEBUG -DWIN32 -DWINVER=$(WINVER) -D_WIN32_WINNT=$(WINVER) $(CFLAGS_DEPR)
install.exe: dosinst.c dosinst.h version.h
$(CC) $(CFLAGS_INST) dosinst.c kernel32.lib shell32.lib \
fprintf(fd, "@echo off\n");
fprintf(fd, "rem -- Run Vim --\n");
+ fprintf(fd, VIMBAT_UNINSTKEY "\n");
fprintf(fd, "\n");
fprintf(fd, "setlocal\n");
"vimtutor.bat", "vimtutor.bat", ""},
};
+/* Uninstall key for vim.bat, etc. */
+#define VIMBAT_UNINSTKEY "rem # uninstall key: " VIM_VERSION_NODOT " #"
+
#define ICON_COUNT 3
char *(icon_names[ICON_COUNT]) =
{"gVim " VIM_VERSION_SHORT,
{
FILE *fd;
char line[BUFSIZE];
- char *p;
- int ver_len = strlen(VIM_VERSION_NODOT);
+ int key_len = strlen(VIMBAT_UNINSTKEY);
int found = FALSE;
fd = fopen(path, "r");
{
while (fgets(line, sizeof(line), fd) != NULL)
{
- for (p = line; *p != 0; ++p)
- // don't accept "vim60an" when looking for "vim60".
- if (strnicmp(p, VIM_VERSION_NODOT, ver_len) == 0
- && !isdigit(p[ver_len])
- && !isalpha(p[ver_len]))
- {
- found = TRUE;
- break;
- }
- if (found)
+ if (strncmp(line, VIMBAT_UNINSTKEY, key_len) == 0)
+ {
+ found = TRUE;
break;
+ }
}
fclose(fd);
}
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 273,
/**/
272,
/**/