patch 9.0.0436: CI: running tests in parallel causes flakiness
Problem: CI: running tests in parallel causes flakiness. Solution: Reorganize the MS-Windows runs. (Ken Takata, closes #11101)
This commit is contained in:
		
							
								
								
									
										192
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										192
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @ -382,35 +382,15 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         toolchain: [msvc, mingw] |  | ||||||
|         arch: [x64, x86] |  | ||||||
|         features: [HUGE, NORMAL] |  | ||||||
|         include: |         include: | ||||||
|           - arch: x64 |           - { features: HUGE,   toolchain: msvc,  VIMDLL: no,  GUI: no,  arch: x64 } | ||||||
|             vcarch: amd64 |           - { features: HUGE,   toolchain: mingw, VIMDLL: yes, GUI: yes, arch: x86, coverage: yes } | ||||||
|             warch: x64 |           - { features: HUGE,   toolchain: msvc,  VIMDLL: no,  GUI: yes, arch: x86 } | ||||||
|             bits: 64 |           - { features: HUGE,   toolchain: mingw, VIMDLL: yes, GUI: no,  arch: x64, coverage: yes } | ||||||
|             msystem: MINGW64 |           - { features: NORMAL, toolchain: msvc,  VIMDLL: yes, GUI: no,  arch: x86 } | ||||||
|             cygreg: registry |           - { features: NORMAL, toolchain: mingw, VIMDLL: no,  GUI: yes, arch: x64 } | ||||||
|             pyreg: "" |           - { features: TINY,   toolchain: msvc,  VIMDLL: yes, GUI: yes, arch: x64 } | ||||||
|           - arch: x86 |           - { features: TINY,   toolchain: mingw, VIMDLL: no,  GUI: no,  arch: x86 } | ||||||
|             vcarch: x86 |  | ||||||
|             warch: ia32 |  | ||||||
|             bits: 32 |  | ||||||
|             msystem: MINGW32 |  | ||||||
|             cygreg: registry32 |  | ||||||
|             pyreg: "-32" |  | ||||||
|           - toolchain: mingw |  | ||||||
|             arch: x64 |  | ||||||
|             features: HUGE |  | ||||||
|             coverage: yes |  | ||||||
|         exclude: |  | ||||||
|           - toolchain: msvc |  | ||||||
|             arch: x64 |  | ||||||
|             features: NORMAL |  | ||||||
|           - toolchain: mingw |  | ||||||
|             arch: x86 |  | ||||||
|             features: NORMAL |  | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Initialize |       - name: Initialize | ||||||
| @ -418,13 +398,32 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|           git config --global core.autocrlf input |           git config --global core.autocrlf input | ||||||
|           echo "VCVARSALL=$(vswhere -products \* -latest -property installationPath)\\VC\\Auxiliary\\Build\\vcvarsall.bat" >> $GITHUB_ENV |  | ||||||
|           if [ "${{ matrix.arch }}" = "x86" ]; then |           if [ "${{ matrix.arch }}" = "x64" ]; then | ||||||
|             choco install python2 --forcex86 |             cygreg=registry | ||||||
|  |             pyreg= | ||||||
|  |             echo "VCARCH=amd64" >> $GITHUB_ENV | ||||||
|  |             echo "WARCH=x64" >> $GITHUB_ENV | ||||||
|  |             echo "BITS=64" >> $GITHUB_ENV | ||||||
|  |             echo "MSYSTEM=MINGW64" >> $GITHUB_ENV | ||||||
|           else |           else | ||||||
|             choco install python2 |             cygreg=registry32 | ||||||
|  |             pyreg=-32 | ||||||
|  |             echo "VCARCH=x86" >> $GITHUB_ENV | ||||||
|  |             echo "WARCH=ia32" >> $GITHUB_ENV | ||||||
|  |             echo "BITS=32" >> $GITHUB_ENV | ||||||
|  |             echo "MSYSTEM=MINGW32" >> $GITHUB_ENV | ||||||
|           fi |           fi | ||||||
|           python3_dir=$(cat "/proc/${{ matrix.cygreg }}/HKEY_LOCAL_MACHINE/SOFTWARE/Python/PythonCore/${PYTHON3_VER_DOT}${{ matrix.pyreg }}/InstallPath/@") |  | ||||||
|  |           echo "VCVARSALL=$(vswhere -products \* -latest -property installationPath)\\VC\\Auxiliary\\Build\\vcvarsall.bat" >> $GITHUB_ENV | ||||||
|  |           if [ "${{ matrix.features }}" != "TINY" ]; then | ||||||
|  |             if [ "${{ matrix.arch }}" = "x86" ]; then | ||||||
|  |               choco install python2 --forcex86 | ||||||
|  |             else | ||||||
|  |               choco install python2 | ||||||
|  |             fi | ||||||
|  |           fi | ||||||
|  |           python3_dir=$(cat "/proc/$cygreg/HKEY_LOCAL_MACHINE/SOFTWARE/Python/PythonCore/${PYTHON3_VER_DOT}$pyreg/InstallPath/@") | ||||||
|           echo "PYTHON3_DIR=$python3_dir" >> $GITHUB_ENV |           echo "PYTHON3_DIR=$python3_dir" >> $GITHUB_ENV | ||||||
|  |  | ||||||
|       - uses: msys2/setup-msys2@v2 |       - uses: msys2/setup-msys2@v2 | ||||||
| @ -434,7 +433,7 @@ jobs: | |||||||
|           install: tar |           install: tar | ||||||
|           pacboy: >- |           pacboy: >- | ||||||
|             make:p gcc:p |             make:p gcc:p | ||||||
|           msystem: ${{ matrix.msystem }} |           msystem: ${{ env.MSYSTEM }} | ||||||
|           release: false |           release: false | ||||||
|  |  | ||||||
|       - name: Checkout repository from github |       - name: Checkout repository from github | ||||||
| @ -451,7 +450,7 @@ jobs: | |||||||
|         uses: actions/cache@v3 |         uses: actions/cache@v3 | ||||||
|         with: |         with: | ||||||
|           path: downloads |           path: downloads | ||||||
|           key: ${{ runner.os }}-${{ matrix.bits }}-${{ hashFiles('urls.txt') }} |           key: ${{ runner.os }}-${{ matrix.arch }}-${{ hashFiles('urls.txt') }} | ||||||
|  |  | ||||||
|       - name: Download dependencies |       - name: Download dependencies | ||||||
|         shell: cmd |         shell: cmd | ||||||
| @ -460,14 +459,14 @@ jobs: | |||||||
|           if not exist downloads mkdir downloads |           if not exist downloads mkdir downloads | ||||||
|  |  | ||||||
|           echo %COL_GREEN%Download Lua%COL_RESET% |           echo %COL_GREEN%Download Lua%COL_RESET% | ||||||
|           call :downloadfile %LUA${{ matrix.bits }}_URL% downloads\lua.zip |           call :downloadfile %LUA${{ env.BITS }}_URL% downloads\lua.zip | ||||||
|           7z x downloads\lua.zip -o%LUA_DIR% > nul || exit 1 |           7z x downloads\lua.zip -o%LUA_DIR% > nul || exit 1 | ||||||
|  |  | ||||||
|           echo %COL_GREEN%Download winpty%COL_RESET% |           echo %COL_GREEN%Download winpty%COL_RESET% | ||||||
|           call :downloadfile %WINPTY_URL% downloads\winpty.zip |           call :downloadfile %WINPTY_URL% downloads\winpty.zip | ||||||
|           7z x -y downloads\winpty.zip -oD:\winpty > nul || exit 1 |           7z x -y downloads\winpty.zip -oD:\winpty > nul || exit 1 | ||||||
|           copy /Y D:\winpty\${{ matrix.warch }}\bin\winpty.dll        src\winpty${{ matrix.bits }}.dll |           copy /Y D:\winpty\%WARCH%\bin\winpty.dll        src\winpty%BITS%.dll | ||||||
|           copy /Y D:\winpty\${{ matrix.warch }}\bin\winpty-agent.exe  src\ |           copy /Y D:\winpty\%WARCH%\bin\winpty-agent.exe  src\ | ||||||
|  |  | ||||||
|           goto :eof |           goto :eof | ||||||
|  |  | ||||||
| @ -482,31 +481,28 @@ jobs: | |||||||
|           ) |           ) | ||||||
|           goto :eof |           goto :eof | ||||||
|  |  | ||||||
|       - name: Copy src directory to src2 |  | ||||||
|         shell: cmd |  | ||||||
|         run: xcopy src src2\ /E > nul |  | ||||||
|  |  | ||||||
|       - name: Build (MSVC) |       - name: Build (MSVC) | ||||||
|         if: matrix.toolchain == 'msvc' |         if: matrix.toolchain == 'msvc' | ||||||
|         shell: cmd |         shell: cmd | ||||||
|         run: | |         run: | | ||||||
|           call "%VCVARSALL%" ${{ matrix.vcarch }} |           call "%VCVARSALL%" %VCARCH% | ||||||
|           cd src |           cd src | ||||||
|  |           if "${{ matrix.VIMDLL }}"=="yes" ( | ||||||
|  |             set GUI=yes | ||||||
|  |           ) else ( | ||||||
|  |             set GUI=${{ matrix.GUI }} | ||||||
|  |           ) | ||||||
|           if "${{ matrix.features }}"=="HUGE" ( |           if "${{ matrix.features }}"=="HUGE" ( | ||||||
|             nmake -nologo -f Make_mvc.mak ^ |             nmake -nologo -f Make_mvc.mak ^ | ||||||
|               FEATURES=${{ matrix.features }} ^ |               FEATURES=${{ matrix.features }} ^ | ||||||
|               GUI=yes IME=yes ICONV=yes VIMDLL=yes ^ |               GUI=%GUI% IME=yes ICONV=yes VIMDLL=${{ matrix.VIMDLL }} ^ | ||||||
|               DYNAMIC_LUA=yes LUA=%LUA_DIR% ^ |               DYNAMIC_LUA=yes LUA=%LUA_DIR% ^ | ||||||
|               DYNAMIC_PYTHON=yes PYTHON=%PYTHON_DIR% ^ |               DYNAMIC_PYTHON=yes PYTHON=%PYTHON_DIR% ^ | ||||||
|               DYNAMIC_PYTHON3=yes PYTHON3=%PYTHON3_DIR% |               DYNAMIC_PYTHON3=yes PYTHON3=%PYTHON3_DIR% | ||||||
|           ) else ( |           ) else ( | ||||||
|             nmake -nologo -f Make_mvc.mak ^ |             nmake -nologo -f Make_mvc.mak ^ | ||||||
|               FEATURES=${{ matrix.features }} ^ |               FEATURES=${{ matrix.features }} ^ | ||||||
|               GUI=yes IME=yes ICONV=yes VIMDLL=yes |               GUI=%GUI% IME=yes ICONV=yes VIMDLL=${{ matrix.VIMDLL }} | ||||||
|           ) |  | ||||||
|           if not exist vim${{ matrix.bits }}.dll ( |  | ||||||
|             echo %COL_RED%Build failure.%COL_RESET% |  | ||||||
|             exit 1 |  | ||||||
|           ) |           ) | ||||||
|  |  | ||||||
|       - name: Build (MinGW) |       - name: Build (MinGW) | ||||||
| @ -514,10 +510,15 @@ jobs: | |||||||
|         shell: msys2 {0} |         shell: msys2 {0} | ||||||
|         run: | |         run: | | ||||||
|           cd src |           cd src | ||||||
|  |           if [ "${{ matrix.VIMDLL }}" = "yes" ]; then | ||||||
|  |             GUI=yes | ||||||
|  |           else | ||||||
|  |             GUI=${{ matrix.GUI }} | ||||||
|  |           fi | ||||||
|           if [ "${{ matrix.features }}" = "HUGE" ]; then |           if [ "${{ matrix.features }}" = "HUGE" ]; then | ||||||
|             mingw32-make -f Make_ming.mak -j2 \ |             mingw32-make -f Make_ming.mak -j2 \ | ||||||
|               FEATURES=${{ matrix.features }} \ |               FEATURES=${{ matrix.features }} \ | ||||||
|               GUI=yes IME=yes ICONV=yes VIMDLL=yes \ |               GUI=$GUI IME=yes ICONV=yes VIMDLL=${{ matrix.VIMDLL }} \ | ||||||
|               DYNAMIC_LUA=yes LUA=${LUA_DIR_SLASH} \ |               DYNAMIC_LUA=yes LUA=${LUA_DIR_SLASH} \ | ||||||
|               DYNAMIC_PYTHON=yes PYTHON=${PYTHON_DIR} \ |               DYNAMIC_PYTHON=yes PYTHON=${PYTHON_DIR} \ | ||||||
|               DYNAMIC_PYTHON3=yes PYTHON3=${PYTHON3_DIR} \ |               DYNAMIC_PYTHON3=yes PYTHON3=${PYTHON3_DIR} \ | ||||||
| @ -525,17 +526,27 @@ jobs: | |||||||
|           else |           else | ||||||
|             mingw32-make -f Make_ming.mak -j2 \ |             mingw32-make -f Make_ming.mak -j2 \ | ||||||
|               FEATURES=${{ matrix.features }} \ |               FEATURES=${{ matrix.features }} \ | ||||||
|               GUI=yes IME=yes ICONV=yes VIMDLL=yes \ |               GUI=$GUI IME=yes ICONV=yes VIMDLL=${{ matrix.VIMDLL }} \ | ||||||
|               STATIC_STDCPLUS=yes |               STATIC_STDCPLUS=yes | ||||||
|           fi |           fi | ||||||
|  |  | ||||||
|       - name: Check version |       - name: Check version | ||||||
|         shell: cmd |         shell: cmd | ||||||
|         run: | |         run: | | ||||||
|           PATH %LUA_DIR%;C:\msys64\${{ matrix.msystem }}\bin;%PATH%;%PYTHON3_DIR% |           PATH %LUA_DIR%;C:\msys64\%MSYSTEM%\bin;%PATH%;%PYTHON3_DIR% | ||||||
|           src\vim --version || exit 1 |           if "${{ matrix.GUI }}"=="yes" ( | ||||||
|           src\vim -u NONE -i NONE --not-a-term -esNX -V1 -S ci/if_ver-1.vim -c quit |             start /wait src\gvim -u NONE -i NONE -c "redir > version.txt | ver | q" || exit 1 | ||||||
|           src\vim -u NONE -i NONE --not-a-term -esNX -V1 -S ci/if_ver-2.vim -c quit |             type version.txt | ||||||
|  |             echo. | ||||||
|  |             start /wait src\gvim -u NONE -i NONE -c "redir! > version.txt | so ci\if_ver-1.vim | q" | ||||||
|  |             start /wait src\gvim -u NONE -i NONE -c "redir >> version.txt | so ci\if_ver-2.vim | q" | ||||||
|  |             type version.txt | ||||||
|  |             del version.txt | ||||||
|  |           ) else ( | ||||||
|  |             src\vim --version || exit 1 | ||||||
|  |             src\vim -u NONE -i NONE --not-a-term -esNX -V1 -S ci/if_ver-1.vim -c quit | ||||||
|  |             src\vim -u NONE -i NONE --not-a-term -esNX -V1 -S ci/if_ver-2.vim -c quit | ||||||
|  |           ) | ||||||
|  |  | ||||||
|       #- name: Prepare Artifact |       #- name: Prepare Artifact | ||||||
|       #  shell: cmd |       #  shell: cmd | ||||||
| @ -550,51 +561,39 @@ jobs: | |||||||
|       #    name: vim${{ matrix.bits }}-${{ matrix.toolchain }} |       #    name: vim${{ matrix.bits }}-${{ matrix.toolchain }} | ||||||
|       #    path: ./artifacts |       #    path: ./artifacts | ||||||
|  |  | ||||||
|       - name: Copy gcov data files to src2 |  | ||||||
|         if: matrix.coverage |  | ||||||
|         shell: msys2 {0} |  | ||||||
|         run: find src -name '*.gcno' | tar -c -T - | tar -x -C src2 --strip-components 1 |  | ||||||
|  |  | ||||||
|       - name: Test and show the result of testing gVim |       - name: Test and show the result of testing gVim | ||||||
|  |         if: matrix.GUI == 'yes' || matrix.VIMDLL == 'yes' | ||||||
|         shell: cmd |         shell: cmd | ||||||
|         timeout-minutes: 20 |         timeout-minutes: 15 | ||||||
|         run: | |         run: | | ||||||
|           PATH %LUA_DIR%;C:\msys64\${{ matrix.msystem }}\bin;%PATH%;%PYTHON3_DIR% |           PATH %LUA_DIR%;C:\msys64\%MSYSTEM%\bin;%PATH%;%PYTHON3_DIR% | ||||||
|           call "%VCVARSALL%" ${{ matrix.vcarch }} |           call "%VCVARSALL%" %VCARCH% | ||||||
|  |  | ||||||
|           echo %COL_GREEN%Start testing Vim in background.%COL_RESET% |  | ||||||
|           start cmd /c "cd src2\testdir & nmake -nologo -f Make_mvc.mak VIMPROG=..\..\src\vim > nul & echo done>done.txt" |  | ||||||
|  |  | ||||||
|           echo %COL_GREEN%Test gVim:%COL_RESET% |           echo %COL_GREEN%Test gVim:%COL_RESET% | ||||||
|           cd src\testdir |           cd src\testdir | ||||||
|           nmake -nologo -f Make_mvc.mak VIMPROG=..\gvim || exit 1 |           if "${{ matrix.GUI }}"=="yes" ( | ||||||
|  |             nmake -nologo -f Make_mvc.mak VIMPROG=..\gvim || exit 1 | ||||||
|       - name: Show the result of testing Vim |           ) else ( | ||||||
|         shell: cmd |             @rem Run only tiny tests. | ||||||
|         timeout-minutes: 20 |             nmake -nologo -f Make_mvc.mak tiny VIMPROG=..\gvim  || exit 1 | ||||||
|         run: | |  | ||||||
|           PATH %LUA_DIR%;C:\msys64\${{ matrix.msystem }}\bin;%PATH%;%PYTHON3_DIR% |  | ||||||
|           call "%VCVARSALL%" ${{ matrix.vcarch }} |  | ||||||
|  |  | ||||||
|           echo %COL_GREEN%Wait for Vim tests to finish.%COL_RESET% |  | ||||||
|           cd src2\testdir |  | ||||||
|           :: Wait about 10 minutes. |  | ||||||
|           for /L %%i in (1,1,60) do ( |  | ||||||
|             if exist done.txt goto exitloop |  | ||||||
|             timeout 10 > NUL 2>&1 |  | ||||||
|             if ERRORLEVEL 1 ping -n 11 localhost > NUL |  | ||||||
|           ) |           ) | ||||||
|           set timeout=1 |  | ||||||
|           :exitloop |  | ||||||
|  |  | ||||||
|           echo %COL_GREEN%The result of testing Vim:%COL_RESET% |       - name: Test and show the result of testing Vim | ||||||
|           cd src2\testdir |         if: matrix.GUI == 'no' || matrix.VIMDLL == 'yes' | ||||||
|           if exist messages type messages |         shell: cmd | ||||||
|           nmake -nologo -f Make_mvc.mak report VIMPROG=..\..\src\vim || exit 1 |         timeout-minutes: 15 | ||||||
|  |         run: | | ||||||
|  |           PATH %LUA_DIR%;C:\msys64\%MSYSTEM%\bin;%PATH%;%PYTHON3_DIR% | ||||||
|  |           call "%VCVARSALL%" %VCARCH% | ||||||
|  |  | ||||||
|           if "%timeout%"=="1" ( |           echo %COL_GREEN%Test Vim:%COL_RESET% | ||||||
|             echo %COL_RED%Timed out.%COL_RESET% |           cd src\testdir | ||||||
|             exit 1 |           nmake -nologo -f Make_mvc.mak clean | ||||||
|  |           if "${{ matrix.GUI }}"=="no" ( | ||||||
|  |             nmake -nologo -f Make_mvc.mak VIMPROG=..\vim || exit 1 | ||||||
|  |           ) else ( | ||||||
|  |             @rem Run only tiny tests. | ||||||
|  |             nmake -nologo -f Make_mvc.mak tiny VIMPROG=..\vim  || exit 1 | ||||||
|           ) |           ) | ||||||
|  |  | ||||||
|       - name: Generate gcov files |       - name: Generate gcov files | ||||||
| @ -603,19 +602,10 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           cd src |           cd src | ||||||
|           find . -type f -name '*.gcno' -exec gcov -pb {} + || true |           find . -type f -name '*.gcno' -exec gcov -pb {} + || true | ||||||
|           cd ../src2 |  | ||||||
|           find . -type f -name '*.gcno' -exec gcov -pb {} + || true |  | ||||||
|  |  | ||||||
|       - name: Codecov (gVim) |       - name: Codecov | ||||||
|         if: matrix.coverage |         if: matrix.coverage | ||||||
|         uses: codecov/codecov-action@v3.1.0 |         uses: codecov/codecov-action@v3.1.0 | ||||||
|         with: |         with: | ||||||
|           directory: src |           directory: src | ||||||
|           flags: windows,${{ matrix.toolchain }}-${{ matrix.arch }}-${{ matrix.features }}-gui |  | ||||||
|  |  | ||||||
|       - name: Codecov (Vim) |  | ||||||
|         if: matrix.coverage |  | ||||||
|         uses: codecov/codecov-action@v3.1.0 |  | ||||||
|         with: |  | ||||||
|           directory: src2 |  | ||||||
|           flags: windows,${{ matrix.toolchain }}-${{ matrix.arch }}-${{ matrix.features }} |           flags: windows,${{ matrix.toolchain }}-${{ matrix.arch }}-${{ matrix.features }} | ||||||
|  | |||||||
| @ -2011,11 +2011,11 @@ EXTERN char e_cannot_delete_variable[] | |||||||
| 	INIT(= N_("E795: Cannot delete variable")); | 	INIT(= N_("E795: Cannot delete variable")); | ||||||
| EXTERN char e_cannot_delete_variable_str[] | EXTERN char e_cannot_delete_variable_str[] | ||||||
| 	INIT(= N_("E795: Cannot delete variable %s")); | 	INIT(= N_("E795: Cannot delete variable %s")); | ||||||
|  | #endif | ||||||
|  | #ifdef MSWIN | ||||||
| 	// E796 | 	// E796 | ||||||
| # ifdef MSWIN |  | ||||||
| EXTERN char e_writing_to_device_disabled_with_opendevice_option[] | EXTERN char e_writing_to_device_disabled_with_opendevice_option[] | ||||||
| 	INIT(= N_("writing to device disabled with 'opendevice' option")); | 	INIT(= N_("writing to device disabled with 'opendevice' option")); | ||||||
| # endif |  | ||||||
| #endif | #endif | ||||||
| #ifdef FEAT_SPELL | #ifdef FEAT_SPELL | ||||||
| EXTERN char e_spellfilemising_autocommand_deleted_buffer[] | EXTERN char e_spellfilemising_autocommand_deleted_buffer[] | ||||||
|  | |||||||
| @ -198,9 +198,7 @@ gui_mch_set_rendering_options(char_u *s) | |||||||
| # ifndef __MINGW32__ | # ifndef __MINGW32__ | ||||||
| #  include <shellapi.h> | #  include <shellapi.h> | ||||||
| # endif | # endif | ||||||
| # if defined(FEAT_TOOLBAR) || defined(FEAT_BEVAL_GUI) || defined(FEAT_GUI_TABLINE) | # include <commctrl.h> | ||||||
| #  include <commctrl.h> |  | ||||||
| # endif |  | ||||||
| # include <windowsx.h> | # include <windowsx.h> | ||||||
|  |  | ||||||
| #endif // PROTO | #endif // PROTO | ||||||
|  | |||||||
| @ -2834,7 +2834,11 @@ SaveConsoleTitleAndIcon(void) | |||||||
| 	return; | 	return; | ||||||
|  |  | ||||||
|     // Extract the first icon contained in the Vim executable. |     // Extract the first icon contained in the Vim executable. | ||||||
|     if (mch_icon_load((HANDLE *)&g_hVimIcon) == FAIL || g_hVimIcon == NULL) |     if ( | ||||||
|  | # ifdef FEAT_LIBCALL | ||||||
|  | 	    mch_icon_load((HANDLE *)&g_hVimIcon) == FAIL || | ||||||
|  | # endif | ||||||
|  | 	    g_hVimIcon == NULL) | ||||||
| 	g_hVimIcon = ExtractIcon(NULL, (LPCSTR)exe_name, 0); | 	g_hVimIcon = ExtractIcon(NULL, (LPCSTR)exe_name, 0); | ||||||
|     if (g_hVimIcon != NULL) |     if (g_hVimIcon != NULL) | ||||||
| 	g_fCanChangeIcon = TRUE; | 	g_fCanChangeIcon = TRUE; | ||||||
|  | |||||||
| @ -703,6 +703,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 */ | ||||||
|  | /**/ | ||||||
|  |     436, | ||||||
| /**/ | /**/ | ||||||
|     435, |     435, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user