[gtk/msvcproj-git: 8/10] win32: Split out MSVC project generating




commit a2e3f5c7a6978fb1fd7499cedb184f37d766d4bc
Author: Chun-wei Fan <fanchunwei src gnome org>
Date:   Fri Aug 5 11:42:00 2022 +0800

    win32: Split out MSVC project generating
    
    ...into a NMake Makefile snippet of its own, to make things clearer and easier
    to maintain.  The regenerating target should still be invoked using
    generate-msvc.mak.

 win32/Makefile.am            |   1 +
 win32/config-msvc.mak.in     | 212 ----------------
 win32/generate-msvc.mak      | 357 +-------------------------
 win32/generate-msvcprojs.mak | 578 +++++++++++++++++++++++++++++++++++++++++++
 4 files changed, 580 insertions(+), 568 deletions(-)
---
diff --git a/win32/Makefile.am b/win32/Makefile.am
index bc7a513ad5..ade6e9c199 100644
--- a/win32/Makefile.am
+++ b/win32/Makefile.am
@@ -19,6 +19,7 @@ EXTRA_DIST += \
        detectenv-msvc.mak              \
        gen-version-items.py    \
        generate-msvc.mak       \
+       generate-msvcprojs.mak  \
        gtk-introspection-msvc.mak      \
        introspection-msvc.mak          \
        install-msvc.mak                \
diff --git a/win32/config-msvc.mak.in b/win32/config-msvc.mak.in
index 74abc4196d..0f19043f1d 100644
--- a/win32/config-msvc.mak.in
+++ b/win32/config-msvc.mak.in
@@ -126,215 +126,3 @@ GTK_PREPROCESSOR_FLAGS =  \
         /DGTK_BINARY_VERSION=\"3.0.0\" \
         /DGDK_DISABLE_DEPRECATED       \
         /DISOLATION_AWARE_ENABLED
-
-GTK3_VS10_STATIC_PROJS =       \
-       vs10\gtk+.sln   \
-       vs10\gtk-builder-tool.vcxproj   \
-       vs10\gtk-encode-symbolic-svg.vcxproj    \
-       vs10\gtk-query-settings.vcxproj \
-       vs10\gtk-update-icon-cache.vcxproj      \
-       vs10\gtk3-demo-application.vcxproj      \
-       vs10\gtk3-icon-browser.vcxproj  \
-       vs10\gtk3-install.vcxproj       \
-       vs10\gtk3-introspect.vcxproj    \
-       vs10\gtk3-prebuild.vcxproj      \
-       vs10\gtk3-widget-factory.vcxproj        \
-       vs10\gtk-builder-tool.vcxproj.filters   \
-       vs10\gtk-encode-symbolic-svg.vcxproj.filters    \
-       vs10\gtk-query-settings.vcxproj.filters \
-       vs10\gtk-update-icon-cache.vcxproj.filters      \
-       vs10\gtk3-demo-application.vcxproj.filters      \
-       vs10\gtk3-icon-browser.vcxproj.filters  \
-       vs10\gtk3-widget-factory.vcxproj.filters
-
-GTK3_VS11_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs11\)
-GTK3_VS12_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs12\)
-GTK3_VS14_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs14\)
-GTK3_VS15_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs15\)
-GTK3_VS16_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs16\)
-GTK3_VS17_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs17\)
-
-GDK_VS9_PROJ = gdk-3.vcproj
-GDKWIN32_VS9_PROJ = gdk3-win32.vcproj
-GDKBROADWAY_VS9_PROJ = $(GDKWIN32_VS9_PROJ:-win32=-broadway)
-GTK_VS9_PROJ = gtk-3.vcproj
-GAILUTIL_VS9_PROJ = gailutil-3.vcproj
-BROADWAYD_VS9_PROJ = broadwayd.vcproj
-DEMO_VS9_PROJ = gtk3-demo.vcproj
-
-GDK_VS1X_PROJ = $(GDK_VS9_PROJ:.vcproj=.vcxproj)
-GDKWIN32_VS1X_PROJ = $(GDKWIN32_VS9_PROJ:.vcproj=.vcxproj)
-GDKBROADWAY_VS1X_PROJ = $(GDKBROADWAY_VS9_PROJ:.vcproj=.vcxproj)
-GTK_VS1X_PROJ = $(GTK_VS9_PROJ:.vcproj=.vcxproj)
-GAILUTIL_VS1X_PROJ = $(GAILUTIL_VS9_PROJ:.vcproj=.vcxproj)
-BROADWAYD_VS1X_PROJ = $(BROADWAYD_VS9_PROJ:.vcproj=.vcxproj)
-DEMO_VS1X_PROJ = $(DEMO_VS9_PROJ:.vcproj=.vcxproj)
-
-GDK_VS1X_PROJ_FILTERS = $(GDK_VS9_PROJ:.vcproj=.vcxproj.filters)
-GDKWIN32_VS1X_PROJ_FILTERS = $(GDKWIN32_VS9_PROJ:.vcproj=.vcxproj.filters)
-GDKBROADWAY_VS1X_PROJ_FILTERS = $(GDKBROADWAY_VS9_PROJ:.vcproj=.vcxproj.filters)
-GTK_VS1X_PROJ_FILTERS = $(GTK_VS9_PROJ:.vcproj=.vcxproj.filters)
-GAILUTIL_VS1X_PROJ_FILTERS = $(GAILUTIL_VS9_PROJ:.vcproj=.vcxproj.filters)
-BROADWAYD_VS1X_PROJ_FILTERS = $(BROADWAYD_VS9_PROJ:.vcproj=.vcxproj.filters)
-DEMO_VS1X_PROJ_FILTERS = $(DEMO_VS9_PROJ:.vcproj=.vcxproj.filters)
-
-GTK3_GDK_VC1X_PROJS =  \
-       vs10\$(GDK_VS1X_PROJ)   \
-       vs11\$(GDK_VS1X_PROJ)   \
-       vs12\$(GDK_VS1X_PROJ)   \
-       vs14\$(GDK_VS1X_PROJ)   \
-       vs15\$(GDK_VS1X_PROJ)   \
-       vs16\$(GDK_VS1X_PROJ)   \
-       vs17\$(GDK_VS1X_PROJ)
-
-GTK3_GDK_VC1X_PROJ_FILTERS =   \
-       vs11\$(GDK_VS1X_PROJ_FILTERS)   \
-       vs12\$(GDK_VS1X_PROJ_FILTERS)   \
-       vs14\$(GDK_VS1X_PROJ_FILTERS)   \
-       vs15\$(GDK_VS1X_PROJ_FILTERS)   \
-       vs16\$(GDK_VS1X_PROJ_FILTERS)   \
-       vs17\$(GDK_VS1X_PROJ_FILTERS)
-
-GTK3_GDK_WIN32_VC1X_PROJS =    \
-       vs10\$(GDKWIN32_VS1X_PROJ)      \
-       vs11\$(GDKWIN32_VS1X_PROJ)      \
-       vs12\$(GDKWIN32_VS1X_PROJ)      \
-       vs14\$(GDKWIN32_VS1X_PROJ)      \
-       vs15\$(GDKWIN32_VS1X_PROJ)      \
-       vs16\$(GDKWIN32_VS1X_PROJ)      \
-       vs17\$(GDKWIN32_VS1X_PROJ)
-
-GTK3_GDK_WIN32_VC1X_PROJ_FILTERS =     \
-       vs11\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
-       vs12\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
-       vs14\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
-       vs15\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
-       vs16\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
-       vs17\$(GDKWIN32_VS1X_PROJ_FILTERS)
-
-GTK3_GDK_BROADWAY_VC1X_PROJS = \
-       vs10\$(GDKBROADWAY_VS1X_PROJ)   \
-       vs11\$(GDKBROADWAY_VS1X_PROJ)   \
-       vs12\$(GDKBROADWAY_VS1X_PROJ)   \
-       vs14\$(GDKBROADWAY_VS1X_PROJ)   \
-       vs15\$(GDKBROADWAY_VS1X_PROJ)   \
-       vs16\$(GDKBROADWAY_VS1X_PROJ)   \
-       vs17\$(GDKBROADWAY_VS1X_PROJ)
-
-GTK3_GDK_BROADWAY_VC1X_PROJ_FILTERS =  \
-       vs11\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
-       vs12\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
-       vs14\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
-       vs15\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
-       vs16\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
-       vs17\$(GDKBROADWAY_VS1X_PROJ_FILTERS)
-
-GTK3_GTK_VC1X_PROJS =  \
-       vs10\$(GTK_VS1X_PROJ)   \
-       vs11\$(GTK_VS1X_PROJ)   \
-       vs12\$(GTK_VS1X_PROJ)   \
-       vs14\$(GTK_VS1X_PROJ)   \
-       vs15\$(GTK_VS1X_PROJ)   \
-       vs16\$(GTK_VS1X_PROJ)   \
-       vs17\$(GTK_VS1X_PROJ)
-
-GTK3_GTK_VC1X_PROJ_FILTERS =   \
-       vs11\$(GTK_VS1X_PROJ_FILTERS)   \
-       vs12\$(GTK_VS1X_PROJ_FILTERS)   \
-       vs14\$(GTK_VS1X_PROJ_FILTERS)   \
-       vs15\$(GTK_VS1X_PROJ_FILTERS)   \
-       vs16\$(GTK_VS1X_PROJ_FILTERS)   \
-       vs17\$(GTK_VS1X_PROJ_FILTERS)
-
-GTK3_GAILUTIL_VC1X_PROJS =     \
-       vs10\$(GAILUTIL_VS1X_PROJ)      \
-       vs11\$(GAILUTIL_VS1X_PROJ)      \
-       vs12\$(GAILUTIL_VS1X_PROJ)      \
-       vs14\$(GAILUTIL_VS1X_PROJ)      \
-       vs15\$(GAILUTIL_VS1X_PROJ)      \
-       vs16\$(GAILUTIL_VS1X_PROJ)      \
-       vs17\$(GAILUTIL_VS1X_PROJ)
-
-GTK3_GAILUTIL_VC1X_PROJ_FILTERS =      \
-       vs11\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
-       vs12\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
-       vs14\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
-       vs15\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
-       vs16\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
-       vs17\$(GAILUTIL_VS1X_PROJ_FILTERS)
-
-GTK3_BROADWAYD_VC1X_PROJS =    \
-       vs10\$(BROADWAYD_VS1X_PROJ)     \
-       vs11\$(BROADWAYD_VS1X_PROJ)     \
-       vs12\$(BROADWAYD_VS1X_PROJ)     \
-       vs14\$(BROADWAYD_VS1X_PROJ)     \
-       vs15\$(BROADWAYD_VS1X_PROJ)     \
-       vs16\$(BROADWAYD_VS1X_PROJ)     \
-       vs17\$(BROADWAYD_VS1X_PROJ)
-
-GTK3_BROADWAYD_VC1X_PROJ_FILTERS =     \
-       vs11\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
-       vs12\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
-       vs14\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
-       vs15\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
-       vs16\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
-       vs17\$(BROADWAYD_VS1X_PROJ_FILTERS)
-
-GTK3_DEMO_VC1X_PROJS = \
-       vs10\$(DEMO_VS1X_PROJ)  \
-       vs11\$(DEMO_VS1X_PROJ)  \
-       vs12\$(DEMO_VS1X_PROJ)  \
-       vs14\$(DEMO_VS1X_PROJ)  \
-       vs15\$(DEMO_VS1X_PROJ)  \
-       vs16\$(DEMO_VS1X_PROJ)  \
-       vs17\$(DEMO_VS1X_PROJ)
-
-GTK3_DEMO_VC1X_PROJ_FILTERS =  \
-       vs11\$(DEMO_VS1X_PROJ_FILTERS)  \
-       vs12\$(DEMO_VS1X_PROJ_FILTERS)  \
-       vs14\$(DEMO_VS1X_PROJ_FILTERS)  \
-       vs15\$(DEMO_VS1X_PROJ_FILTERS)  \
-       vs16\$(DEMO_VS1X_PROJ_FILTERS)  \
-       vs17\$(DEMO_VS1X_PROJ_FILTERS)
-
-GTK3_GDK_WIN32_VCPROJS =       \
-       vs9\$(GDKWIN32_VS9_PROJ)        \
-       $(GTK3_GDK_WIN32_VC1X_PROJS)    \
-       $(GTK3_GDK_WIN32_VC1X_PROJ_FILTERS)
-
-GTK3_GDK_BROADWAY_VCPROJS =    \
-       vs9\$(GDKBROADWAY_VS9_PROJ)     \
-       $(GTK3_GDK_BROADWAY_VC1X_PROJS) \
-       $(GTK3_GDK_BROADWAY_VC1X_PROJ_FILTERS)
-
-GTK3_BROADWAYD_VCPROJS =       \
-       vs9\$(BROADWAYD_VS9_PROJ)       \
-       $(GTK3_BROADWAYD_VC1X_PROJS)    \
-       $(GTK3_BROADWAYD_VC1X_PROJ_FILTERS)
-
-GTK3_GDK_VCPROJS =     \
-       vs9\$(GDK_VS9_PROJ)     \
-       $(GTK3_GDK_VC1X_PROJS)  \
-       $(GTK3_GDK_VC1X_PROJ_FILTERS)   \
-       $(GTK3_GDK_WIN32_VCPROJS)       \
-       $(GTK3_GDK_BROADWAY_VCPROJS)    \
-       $(GTK3_BROADWAYD_VCPROJS)
-
-GTK3_GTK_VCPROJS =     \
-       vs9\$(GTK_VS9_PROJ)     \
-       $(GTK3_GTK_VC1X_PROJS)  \
-       $(GTK3_GTK_VC1X_PROJ_FILTERS)
-
-GTK3_GAILUTIL_VCPROJS =        \
-       vs9\$(GAILUTIL_VS9_PROJ)        \
-       $(GTK3_GAILUTIL_VC1X_PROJS)     \
-       $(GTK3_GAILUTIL_VC1X_PROJ_FILTERS)
-
-GTK3_DEMO_VCPROJS =    \
-       vs9\$(DEMO_VS9_PROJ)    \
-       $(GTK3_DEMO_VC1X_PROJS) \
-       $(GTK3_DEMO_VC1X_PROJ_FILTERS)
-
-DEMO_DEP_LIBS_NEW_PANGO=harfbuzz.lib
-DEMO_DEP_LIBS_PANGOFT2_VS1X=pangoft2-1.0.lib;harfbuzz.lib;freetype.lib
-DEMO_DEP_LIBS_PANGOFT2_VS9=$(DEMO_DEP_LIBS_PANGOFT2_VS1X:;= )
diff --git a/win32/generate-msvc.mak b/win32/generate-msvc.mak
index c32e908c14..df12bc87b9 100644
--- a/win32/generate-msvc.mak
+++ b/win32/generate-msvc.mak
@@ -6,6 +6,7 @@
 !include config-msvc.mak
 !include ../demos/gtk-demo/demos-sources.mak
 !include create-lists-msvc.mak
+!include generate-msvcprojs.mak
 
 # Copy the pre-defined gdkconfig.h.[win32|win32_broadway]
 !if "$(CFG)" == "release" || "$(CFG)" == "Release"
@@ -285,347 +286,6 @@ generate-base-sources:    \
        @$(GLIB_COMPILE_RESOURCES) --target=$@ --sourcedir=..\demos\widget-factory      \
        --generate-source ..\demos\widget-factory\widget-factory.gresource.xml
 
-# (Re-) generate Visual Studio projects
-# Dependencies for library projects
-gdk-3.sourcefiles      \
-gdk-3.vs10.sourcefiles \
-gdk-3.vs10.sourcefiles.filters: $(GDK_C_SRCS:/=\)
-
-gdk3-win32.sourcefiles \
-gdk3-win32.vs10.sourcefiles    \
-gdk3-win32.vs10.sourcefiles.filters: $(GDK_WIN32_C_SRCS)
-
-gdk3-broadway.sourcefiles      \
-gdk3-broadway.vs10.sourcefiles \
-gdk3-broadway.vs10.sourcefiles.filters: $(GDK_BROADWAY_C_SRCS)
-
-# GTK projects-Darn the fatal error U1095...!
-gtk-3.misc.sourcefiles \
-gtk-3.misc.vs10.sourcefiles    \
-gtk-3.misc.vs10.sourcefiles.filters: $(GTK_MISC_C_SRCS:/=\)
-
-gtk-3.a-h.sourcefiles  \
-gtk-3.a-h.vs10.sourcefiles     \
-gtk-3.a-h.vs10.sourcefiles.filters: $(GTK_C_SRCS_A_H:/=\)
-
-gtk-3.i-w.sourcefiles  \
-gtk-3.i-w.vs10.sourcefiles     \
-gtk-3.i-w.vs10.sourcefiles.filters: $(GTK_C_SRCS_I_W:/=\)
-
-gtk-3.win32.sourcefiles        \
-gtk-3.win32.vs10.sourcefiles   \
-gtk-3.win32.vs10.sourcefiles.filters: $(GTK_OS_WIN32_C_SRCS:/=\) $(GTK_MORE_C_SRCS)
-
-gtk-3.sourcefiles:     \
-       gtk-3.a-h.sourcefiles   \
-       gtk-3.i-w.sourcefiles   \
-       gtk-3.misc.sourcefiles  \
-       gtk-3.win32.sourcefiles
-
-gtk-3.vs10.sourcefiles:        \
-       gtk-3.a-h.vs10.sourcefiles      \
-       gtk-3.i-w.vs10.sourcefiles      \
-       gtk-3.misc.vs10.sourcefiles     \
-       gtk-3.win32.vs10.sourcefiles
-
-gtk-3.vs10.sourcefiles.filters:        \
-       gtk-3.a-h.vs10.sourcefiles.filters      \
-       gtk-3.i-w.vs10.sourcefiles.filters      \
-       gtk-3.misc.vs10.sourcefiles.filters     \
-       gtk-3.win32.vs10.sourcefiles.filters
-
-gtk-3.sourcefiles gtk-3.vs10.sourcefiles gtk-3.vs10.sourcefiles.filters:
-       @echo Genarating the final $@ from $**...
-       @for %%f in ($**) do @type %%f>>$@ & del %%f
-
-gailutil-3.sourcefiles \
-gailutil-3.vs10.sourcefiles    \
-gailutil-3.vs10.sourcefiles.filters: $(GAILUTIL_C_SRCS)
-
-# Dependencies for executable projects
-broadwayd.sourcefiles  \
-broadwayd.vs10.sourcefiles     \
-broadwayd.vs10.sourcefiles.filters: $(BROADWAYD_C_SRCS)
-
-gtk3-demo.sourcefiles  \
-gtk3-demo.vs10.sourcefiles     \
-gtk3-demo.vs10.sourcefiles.filters: $(demo_actual_sources) $(more_demo_sources)
-
-gdk-3.sourcefiles gdk3-win32.sourcefiles       \
-gdk3-broadway.sourcefiles gailutil-3.sourcefiles       \
-broadwayd.sourcefiles gtk3-demo.sourcefiles:
-       @-del vs9\$(@B).vcproj
-       @for %%s in ($**) do @echo.   ^<File RelativePath^="..\%%s" /^>>>$@
-
-gtk-3.a-h.sourcefiles gtk-3.i-w.sourcefiles    \
-gtk-3.misc.sourcefiles gtk-3.win32.sourcefiles:
-       @echo Generating $@...
-       @if exist vs9\$(GTK_VS9_PROJ) del vs9\$(GTK_VS9_PROJ)
-       @for %%s in ($(**:..\gtk\=)) do @echo.   ^<File RelativePath^="..\..\gtk\%%s" /^>>>$@
-
-gdk-3.vs10.sourcefiles \
-gdk3-win32.vs10.sourcefiles    \
-gdk3-broadway.vs10.sourcefiles \
-gailutil-3.vs10.sourcefiles    \
-broadwayd.vs10.sourcefiles     \
-gtk3-demo.vs10.sourcefiles:
-       @echo Generating $@...
-       @-del vs10\$(@B:.vs10=.vcxproj)
-       @for %%s in ($**) do @echo.   ^<ClCompile Include^="..\%%s" /^>>>$@
-
-gtk-3.a-h.vs10.sourcefiles     \
-gtk-3.i-w.vs10.sourcefiles     \
-gtk-3.misc.vs10.sourcefiles    \
-gtk-3.win32.vs10.sourcefiles:
-       @echo Generating $@...
-       @if exist vs10\$(GTK_VS1X_PROJ) del vs10\$(GTK_VS1X_PROJ)
-       @for %%s in ($(**:..\gtk\=)) do @echo.   ^<ClCompile Include^="..\..\gtk\%%s" /^>>>$@
-
-gdk-3.vs10.sourcefiles.filters \
-gdk3-win32.vs10.sourcefiles.filters    \
-gdk3-broadway.vs10.sourcefiles.filters \
-gailutil-3.vs10.sourcefiles.filters    \
-broadwayd.vs10.sourcefiles.filters     \
-gtk3-demo.vs10.sourcefiles.filters:
-       @-del vs10\$(@F:.vs10.sourcefiles=.vcxproj)
-       @for %%s in ($**) do @echo.   ^<ClCompile Include^="..\%%s"^>^<Filter^>Source 
Files^</Filter^>^</ClCompile^>>>$@
-
-gtk-3.a-h.vs10.sourcefiles.filters     \
-gtk-3.i-w.vs10.sourcefiles.filters     \
-gtk-3.misc.vs10.sourcefiles.filters    \
-gtk-3.win32.vs10.sourcefiles.filters:
-       @if exist vs10\$(GTK_VS1X_PROJ_FILTERS) del vs10\$(GTK_VS1X_PROJ_FILTERS)
-       @for %%s in ($(**:..\gtk\=)) do @echo.   ^<ClCompile Include^="..\..\gtk\%%s"^>^<Filter^>Source 
Files^</Filter^>^</ClCompile^>>>$@
-
-# Dependencies for GDK projects
-vs9\$(GDK_VS9_PROJ): gdk-3.sourcefiles vs9\$(GDK_VS9_PROJ)in
-vs9\$(GDKWIN32_VS9_PROJ).pre: gdk3-win32.sourcefiles vs9\$(GDKWIN32_VS9_PROJ)in
-vs9\$(GDKBROADWAY_VS9_PROJ): gdk3-broadway.sourcefiles vs9\$(GDKBROADWAY_VS9_PROJ)in
-vs9\$(GTK_VS9_PROJ): gtk-3.sourcefiles vs9\$(GTK_VS9_PROJ)in
-vs9\$(GAILUTIL_VS9_PROJ): gailutil-3.sourcefiles vs9\$(GAILUTIL_VS9_PROJ)in
-
-vs10\$(GDK_VS1X_PROJ): gdk-3.vs10.sourcefiles vs10\$(GDK_VS1X_PROJ)in
-vs10\$(GDKWIN32_VS1X_PROJ).pre: gdk3-win32.vs10.sourcefiles vs10\$(GDKWIN32_VS1X_PROJ)in
-vs10\$(GDKBROADWAY_VS1X_PROJ): gdk3-broadway.vs10.sourcefiles vs10\$(GDKBROADWAY_VS1X_PROJ)in
-vs10\$(GTK_VS1X_PROJ): gtk-3.vs10.sourcefiles vs10\$(GTK_VS1X_PROJ)in
-vs10\$(GAILUTIL_VS1X_PROJ): gailutil-3.vs10.sourcefiles vs10\$(GAILUTIL_VS1X_PROJ)in
-
-vs10\$(GDK_VS1X_PROJ_FILTERS): gdk-3.vs10.sourcefiles.filters vs10\$(GDK_VS1X_PROJ_FILTERS)in
-vs10\$(GDKWIN32_VS1X_PROJ_FILTERS): gdk3-win32.vs10.sourcefiles.filters vs10\$(GDKWIN32_VS1X_PROJ_FILTERS)in
-vs10\$(GDKBROADWAY_VS1X_PROJ_FILTERS): gdk3-broadway.vs10.sourcefiles.filters 
vs10\$(GDKBROADWAY_VS1X_PROJ_FILTERS)in
-vs10\$(GTK_VS1X_PROJ_FILTERS): gtk-3.vs10.sourcefiles.filters vs10\$(GTK_VS1X_PROJ_FILTERS)in
-vs10\$(GAILUTIL_VS1X_PROJ_FILTERS): gailutil-3.vs10.sourcefiles.filters vs10\$(GAILUTIL_VS1X_PROJ_FILTERS)in
-
-# Dependencies for tool executables
-vs9\$(BROADWAYD_VS9_PROJ): broadwayd.sourcefiles vs9\$(BROADWAYD_VS9_PROJ)in
-vs10\$(BROADWAYD_VS1X_PROJ): broadwayd.vs10.sourcefiles vs10\$(BROADWAYD_VS1X_PROJ)in
-vs10\$(BROADWAYD_VS1X_PROJ_FILTERS): broadwayd.vs10.sourcefiles.filters vs10\$(BROADWAYD_VS1X_PROJ_FILTERS)in
-
-# Dependencies for demos
-vs9\$(DEMO_VS9_PROJ).pre: gtk3-demo.sourcefiles vs9\$(DEMO_VS9_PROJ)in
-vs10\$(DEMO_VS1X_PROJ).pre: gtk3-demo.vs10.sourcefiles vs10\$(DEMO_VS1X_PROJ)in
-vs10\$(DEMO_VS1X_PROJ_FILTERS): gtk3-demo.vs10.sourcefiles.filters vs10\$(DEMO_VS1X_PROJ_FILTERS)in
-
-# Create the project files themselves without customization with options
-vs9\$(GDKWIN32_VS9_PROJ).pre   \
-vs9\$(GDKBROADWAY_VS9_PROJ)    \
-vs9\$(GDK_VS9_PROJ)    \
-vs9\$(GTK_VS9_PROJ)    \
-vs9\$(GAILUTIL_VS9_PROJ)       \
-vs9\$(BROADWAYD_VS9_PROJ)      \
-vs9\$(DEMO_VS9_PROJ).pre       \
-vs10\$(GDKWIN32_VS1X_PROJ).pre \
-vs10\$(GDKBROADWAY_VS1X_PROJ)  \
-vs10\$(GDK_VS1X_PROJ)  \
-vs10\$(GTK_VS1X_PROJ)  \
-vs10\$(GAILUTIL_VS1X_PROJ)     \
-vs10\$(BROADWAYD_VS1X_PROJ)    \
-vs10\$(DEMO_VS1X_PROJ).pre     \
-vs10\$(GDKWIN32_VS1X_PROJ_FILTERS)     \
-vs10\$(GDKBROADWAY_VS1X_PROJ_FILTERS)  \
-vs10\$(GDK_VS1X_PROJ_FILTERS)  \
-vs10\$(GTK_VS1X_PROJ_FILTERS)  \
-vs10\$(GAILUTIL_VS1X_PROJ_FILTERS)     \
-vs10\$(BROADWAYD_VS1X_PROJ_FILTERS)    \
-vs10\$(DEMO_VS1X_PROJ_FILTERS):
-       @$(CPP) /nologo /EP /I. $(@:.pre=)in>$(@F:.pre=).tmp
-       @for /f "usebackq tokens=* delims=" %%l in ($(@F:.pre=).tmp) do @echo %%l>>$@
-       @-del $(@F:.pre=).tmp
-       @-for %%f in ($**) do @if not "%%f" == "$(@:.pre=)in" del %%f
-
-vs9\$(GDKWIN32_VS9_PROJ): vs9\$(GDKWIN32_VS9_PROJ).pre
-vs10\$(GDKWIN32_VS1X_PROJ): vs10\$(GDKWIN32_VS1X_PROJ).pre
-
-vs9\$(DEMO_VS9_PROJ): vs9\$(DEMO_VS9_PROJ).pre
-vs10\$(DEMO_VS1X_PROJ): vs10\$(DEMO_VS1X_PROJ).pre
-
-!ifdef USE_EGL
-regenerate-gdk-vsproj-msg:
-       @echo Regenerating GDK Visual Studio projects with EGL support...
-
-vs9\$(GDKWIN32_VS9_PROJ):
-       @echo Generating $@...
-       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
-       --instring=";INSIDE_GDK_WIN32\""        \
-       --outstring=";INSIDE_GDK_WIN32;GDK_WIN32_ENABLE_EGL\""
-       @-del $**
-
-vs10\$(GDKWIN32_VS1X_PROJ):
-       @echo Generating $@...
-       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
-       --instring=";INSIDE_GDK_WIN32;%"        \
-       --outstring=";INSIDE_GDK_WIN32;GDK_WIN32_ENABLE_EGL;%"
-       @-del $**
-!else
-regenerate-gdk-vsproj-msg:
-       @echo Regenerating GDK Visual Studio projects without EGL support...
-
-vs9\$(GDKWIN32_VS9_PROJ) vs10\$(GDKWIN32_VS1X_PROJ):
-       @echo Renaming $** to $@...
-       @move $** $@
-!endif
-
-!ifdef FONT_FEATURES_DEMO
-!ifdef FONT_FEATURES_USE_PANGOFT2
-vs9\$(DEMO_VS9_PROJ):
-       @echo Generating $@...
-       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
-       --instring="AdditionalDependencies=\"\""        \
-       --outstring="AdditionalDependencies=\"$(DEMO_DEP_LIBS_PANGOFT2_VS9)\""
-       @-del $**
-
-vs10\$(DEMO_VS1X_PROJ):
-       @echo Generating $@...
-       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
-       --instring=">%(AdditionalDependencies)<"        \
-       --outstring=">$(DEMO_DEP_LIBS_PANGOFT2_VS1X);%(AdditionalDependencies)<"
-       @-del $**
-!else
-vs9\$(DEMO_VS9_PROJ):
-       @echo Generating $@...
-       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
-       --instring="AdditionalDependencies=\"\""        \
-       --outstring="AdditionalDependencies=\"$(DEMO_DEP_LIBS_NEW_PANGO)\""
-       @-del $**
-
-vs10\$(DEMO_VS1X_PROJ):
-       @echo Generating $@...
-       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
-       --instring=">%(AdditionalDependencies)<"        \
-       --outstring=">$(DEMO_DEP_LIBS_NEW_PANGO);%(AdditionalDependencies)<"
-       @-del $**
-!endif
-!else
-vs9\$(DEMO_VS9_PROJ) vs10\$(DEMO_VS1X_PROJ):
-       @echo Renaming $** to $@...
-       @move $** $@
-!endif
-
-# VS2012+ .vcxproj: Update the toolset version as appropriate
-{vs10\}.vcxproj{vs11\}.vcxproj:
-       @echo Copying and updating $< for VS2012
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v110<"
-
-{vs10\}.vcxproj{vs12\}.vcxproj:
-       @echo Copying and updating $< for VS2013
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v120<"
-
-{vs10\}.vcxproj{vs14\}.vcxproj:
-       @echo Copying and updating $< for VS2015
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v140<"
-
-{vs10\}.vcxproj{vs15\}.vcxproj:
-       @echo Copying and updating $< for VS2017
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v141<"
-
-{vs10\}.vcxproj{vs16\}.vcxproj:
-       @echo Copying and updating $< for VS2019
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v142<"
-
-{vs10\}.vcxproj{vs17\}.vcxproj:
-       @echo Copying and updating $< for VS2022
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v143<"
-
-# VS2012+ .vcxproj.filters: We simply copy the VS2010 ones
-{vs10\}.filters{vs11\}.filters:
-       @echo Copying $< to $@...
-       @copy $< $@
-
-{vs10\}.filters{vs12\}.filters:
-       @echo Copying $< to $@...
-       @copy $< $@
-
-{vs10\}.filters{vs14\}.filters:
-       @echo Copying $< to $@...
-       @copy $< $@
-
-{vs10\}.filters{vs15\}.filters:
-       @echo Copying $< to $@...
-       @copy $< $@
-
-{vs10\}.filters{vs16\}.filters:
-       @echo Copying $< to $@...
-       @copy $< $@
-
-{vs10\}.filters{vs17\}.filters:
-       @echo Copying $< to $@...
-       @copy $< $@
-
-{vs10\}.sln{vs11\}.sln:
-       @echo Copying and updating $< for VS2012...
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
-       --instring="Format Version 11.00" --outstring="Format Version 12.00"
-       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
-       --instring="# Visual Studio 2010" --outstring="# Visual Studio 2012"
-       @del $@.tmp
-
-{vs10\}.sln{vs12\}.sln:
-       @echo Copying and updating $< for VS2013...
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
-       --instring="Format Version 11.00" --outstring="Format Version 12.00"
-       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
-       --instring="# Visual Studio 2010" --outstring="# Visual Studio 2013"
-       @del $@.tmp
-
-{vs10\}.sln{vs14\}.sln:
-       @echo Copying and updating $< for VS2015...
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
-       --instring="Format Version 11.00" --outstring="Format Version 12.00"
-       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
-       --instring="# Visual Studio 2010" --outstring="# Visual Studio 14"
-       @del $@.tmp
-
-{vs10\}.sln{vs15\}.sln:
-       @echo Copying and updating $< for VS2017...
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
-       --instring="Format Version 11.00" --outstring="Format Version 12.00"
-       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
-       --instring="# Visual Studio 2010" --outstring="# Visual Studio 15"
-       @del $@.tmp
-
-{vs10\}.sln{vs16\}.sln:
-       @echo Copying and updating $< for VS2019...
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
-       --instring="Format Version 11.00" --outstring="Format Version 12.00"
-       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
-       --instring="# Visual Studio 2010" --outstring="# Visual Studio 16"
-       @del $@.tmp
-
-{vs10\}.sln{vs17\}.sln:
-       @echo Copying and updating $< for VS2022...
-       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
-       --instring="Format Version 11.00" --outstring="Format Version 12.00"
-       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
-       --instring="# Visual Studio 2010" --outstring="# Visual Studio 17"
-       @del $@.tmp
-
-copy-update-static-projects:   \
-$(GTK3_VS11_STATIC_PROJS)      \
-$(GTK3_VS12_STATIC_PROJS)      \
-$(GTK3_VS14_STATIC_PROJS)      \
-$(GTK3_VS15_STATIC_PROJS)      \
-$(GTK3_VS16_STATIC_PROJS)      \
-$(GTK3_VS17_STATIC_PROJS)
 
 .\vs$(VSVER)\$(CFG)\$(PLAT)\bin\de.gresource.xml: ..\gtk\emoji\gresource.xml.in
 .\vs$(VSVER)\$(CFG)\$(PLAT)\bin\es.gresource.xml: ..\gtk\emoji\gresource.xml.in
@@ -653,18 +313,6 @@ regenerate-demos-h-win32: ..\demos\gtk-demo\geninclude.py $(demo_actual_sources)
        @$(PYTHON) geninclude.py demos.h.win32 $(demo_sources)
        @cd ..\..\win32
 
-regenerate-gtk-vsproj-msg:
-       @echo Regenerating GTK and gailutil projects...
-
-regenerate-gdk-vsproj: regenerate-gdk-vsproj-msg $(GTK3_GDK_VCPROJS)
-regenerate-gtk-vsproj: regenerate-gtk-vsproj-msg $(GTK3_GTK_VCPROJS) $(GTK3_GAILUTIL_VCPROJS)
-
-regenerate-all-msvc-projs:     \
-       copy-update-static-projects     \
-       regenerate-gdk-vsproj   \
-       regenerate-gtk-vsproj   \
-       regenerate-demos-h-win32
-
 # Remove the generated files
 clean:
        @-del /f /q .\vs$(VSVER)\$(CFG)\$(PLAT)\bin\*.gresource
@@ -704,6 +352,3 @@ clean:
        @if exist ..\gdk-$(CFG)-$(GDK_DEL_CONFIG)-build del ..\gdk-$(CFG)-$(GDK_DEL_CONFIG)-build
        @-del /f /q .\vs$(VSVER)\$(CFG)\$(PLAT)\obj\gdk-3\config.h
        @-rd .\vs$(VSVER)\$(CFG)\$(PLAT)\obj\gdk-3\gdk
-
-.SUFFIXES: .vcxproj .filters .sln 
-
diff --git a/win32/generate-msvcprojs.mak b/win32/generate-msvcprojs.mak
new file mode 100644
index 0000000000..507cb38da6
--- /dev/null
+++ b/win32/generate-msvcprojs.mak
@@ -0,0 +1,578 @@
+# NMake Makefile portion for (re-)generating Visual Studio
+# projects. Items in here should not need to be edited unless
+# one is maintaining the NMake build files.
+
+
+GTK3_VS10_STATIC_PROJS =       \
+       vs10\gtk+.sln   \
+       vs10\gtk-builder-tool.vcxproj   \
+       vs10\gtk-encode-symbolic-svg.vcxproj    \
+       vs10\gtk-query-settings.vcxproj \
+       vs10\gtk-update-icon-cache.vcxproj      \
+       vs10\gtk3-demo-application.vcxproj      \
+       vs10\gtk3-icon-browser.vcxproj  \
+       vs10\gtk3-install.vcxproj       \
+       vs10\gtk3-introspect.vcxproj    \
+       vs10\gtk3-prebuild.vcxproj      \
+       vs10\gtk3-widget-factory.vcxproj        \
+       vs10\gtk-builder-tool.vcxproj.filters   \
+       vs10\gtk-encode-symbolic-svg.vcxproj.filters    \
+       vs10\gtk-query-settings.vcxproj.filters \
+       vs10\gtk-update-icon-cache.vcxproj.filters      \
+       vs10\gtk3-demo-application.vcxproj.filters      \
+       vs10\gtk3-icon-browser.vcxproj.filters  \
+       vs10\gtk3-widget-factory.vcxproj.filters
+
+GTK3_VS11_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs11\)
+GTK3_VS12_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs12\)
+GTK3_VS14_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs14\)
+GTK3_VS15_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs15\)
+GTK3_VS16_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs16\)
+GTK3_VS17_STATIC_PROJS = $(GTK3_VS10_STATIC_PROJS:vs10\=vs17\)
+
+GDK_VS9_PROJ = gdk-3.vcproj
+GDKWIN32_VS9_PROJ = gdk3-win32.vcproj
+GDKBROADWAY_VS9_PROJ = $(GDKWIN32_VS9_PROJ:-win32=-broadway)
+GTK_VS9_PROJ = gtk-3.vcproj
+GAILUTIL_VS9_PROJ = gailutil-3.vcproj
+BROADWAYD_VS9_PROJ = broadwayd.vcproj
+DEMO_VS9_PROJ = gtk3-demo.vcproj
+
+GDK_VS1X_PROJ = $(GDK_VS9_PROJ:.vcproj=.vcxproj)
+GDKWIN32_VS1X_PROJ = $(GDKWIN32_VS9_PROJ:.vcproj=.vcxproj)
+GDKBROADWAY_VS1X_PROJ = $(GDKBROADWAY_VS9_PROJ:.vcproj=.vcxproj)
+GTK_VS1X_PROJ = $(GTK_VS9_PROJ:.vcproj=.vcxproj)
+GAILUTIL_VS1X_PROJ = $(GAILUTIL_VS9_PROJ:.vcproj=.vcxproj)
+BROADWAYD_VS1X_PROJ = $(BROADWAYD_VS9_PROJ:.vcproj=.vcxproj)
+DEMO_VS1X_PROJ = $(DEMO_VS9_PROJ:.vcproj=.vcxproj)
+
+GDK_VS1X_PROJ_FILTERS = $(GDK_VS9_PROJ:.vcproj=.vcxproj.filters)
+GDKWIN32_VS1X_PROJ_FILTERS = $(GDKWIN32_VS9_PROJ:.vcproj=.vcxproj.filters)
+GDKBROADWAY_VS1X_PROJ_FILTERS = $(GDKBROADWAY_VS9_PROJ:.vcproj=.vcxproj.filters)
+GTK_VS1X_PROJ_FILTERS = $(GTK_VS9_PROJ:.vcproj=.vcxproj.filters)
+GAILUTIL_VS1X_PROJ_FILTERS = $(GAILUTIL_VS9_PROJ:.vcproj=.vcxproj.filters)
+BROADWAYD_VS1X_PROJ_FILTERS = $(BROADWAYD_VS9_PROJ:.vcproj=.vcxproj.filters)
+DEMO_VS1X_PROJ_FILTERS = $(DEMO_VS9_PROJ:.vcproj=.vcxproj.filters)
+
+GTK3_GDK_VC1X_PROJS =  \
+       vs10\$(GDK_VS1X_PROJ)   \
+       vs11\$(GDK_VS1X_PROJ)   \
+       vs12\$(GDK_VS1X_PROJ)   \
+       vs14\$(GDK_VS1X_PROJ)   \
+       vs15\$(GDK_VS1X_PROJ)   \
+       vs16\$(GDK_VS1X_PROJ)   \
+       vs17\$(GDK_VS1X_PROJ)
+
+GTK3_GDK_VC1X_PROJ_FILTERS =   \
+       vs11\$(GDK_VS1X_PROJ_FILTERS)   \
+       vs12\$(GDK_VS1X_PROJ_FILTERS)   \
+       vs14\$(GDK_VS1X_PROJ_FILTERS)   \
+       vs15\$(GDK_VS1X_PROJ_FILTERS)   \
+       vs16\$(GDK_VS1X_PROJ_FILTERS)   \
+       vs17\$(GDK_VS1X_PROJ_FILTERS)
+
+GTK3_GDK_WIN32_VC1X_PROJS =    \
+       vs10\$(GDKWIN32_VS1X_PROJ)      \
+       vs11\$(GDKWIN32_VS1X_PROJ)      \
+       vs12\$(GDKWIN32_VS1X_PROJ)      \
+       vs14\$(GDKWIN32_VS1X_PROJ)      \
+       vs15\$(GDKWIN32_VS1X_PROJ)      \
+       vs16\$(GDKWIN32_VS1X_PROJ)      \
+       vs17\$(GDKWIN32_VS1X_PROJ)
+
+GTK3_GDK_WIN32_VC1X_PROJ_FILTERS =     \
+       vs11\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
+       vs12\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
+       vs14\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
+       vs15\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
+       vs16\$(GDKWIN32_VS1X_PROJ_FILTERS)      \
+       vs17\$(GDKWIN32_VS1X_PROJ_FILTERS)
+
+GTK3_GDK_BROADWAY_VC1X_PROJS = \
+       vs10\$(GDKBROADWAY_VS1X_PROJ)   \
+       vs11\$(GDKBROADWAY_VS1X_PROJ)   \
+       vs12\$(GDKBROADWAY_VS1X_PROJ)   \
+       vs14\$(GDKBROADWAY_VS1X_PROJ)   \
+       vs15\$(GDKBROADWAY_VS1X_PROJ)   \
+       vs16\$(GDKBROADWAY_VS1X_PROJ)   \
+       vs17\$(GDKBROADWAY_VS1X_PROJ)
+
+GTK3_GDK_BROADWAY_VC1X_PROJ_FILTERS =  \
+       vs11\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
+       vs12\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
+       vs14\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
+       vs15\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
+       vs16\$(GDKBROADWAY_VS1X_PROJ_FILTERS)   \
+       vs17\$(GDKBROADWAY_VS1X_PROJ_FILTERS)
+
+GTK3_GTK_VC1X_PROJS =  \
+       vs10\$(GTK_VS1X_PROJ)   \
+       vs11\$(GTK_VS1X_PROJ)   \
+       vs12\$(GTK_VS1X_PROJ)   \
+       vs14\$(GTK_VS1X_PROJ)   \
+       vs15\$(GTK_VS1X_PROJ)   \
+       vs16\$(GTK_VS1X_PROJ)   \
+       vs17\$(GTK_VS1X_PROJ)
+
+GTK3_GTK_VC1X_PROJ_FILTERS =   \
+       vs11\$(GTK_VS1X_PROJ_FILTERS)   \
+       vs12\$(GTK_VS1X_PROJ_FILTERS)   \
+       vs14\$(GTK_VS1X_PROJ_FILTERS)   \
+       vs15\$(GTK_VS1X_PROJ_FILTERS)   \
+       vs16\$(GTK_VS1X_PROJ_FILTERS)   \
+       vs17\$(GTK_VS1X_PROJ_FILTERS)
+
+GTK3_GAILUTIL_VC1X_PROJS =     \
+       vs10\$(GAILUTIL_VS1X_PROJ)      \
+       vs11\$(GAILUTIL_VS1X_PROJ)      \
+       vs12\$(GAILUTIL_VS1X_PROJ)      \
+       vs14\$(GAILUTIL_VS1X_PROJ)      \
+       vs15\$(GAILUTIL_VS1X_PROJ)      \
+       vs16\$(GAILUTIL_VS1X_PROJ)      \
+       vs17\$(GAILUTIL_VS1X_PROJ)
+
+GTK3_GAILUTIL_VC1X_PROJ_FILTERS =      \
+       vs11\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
+       vs12\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
+       vs14\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
+       vs15\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
+       vs16\$(GAILUTIL_VS1X_PROJ_FILTERS)      \
+       vs17\$(GAILUTIL_VS1X_PROJ_FILTERS)
+
+GTK3_BROADWAYD_VC1X_PROJS =    \
+       vs10\$(BROADWAYD_VS1X_PROJ)     \
+       vs11\$(BROADWAYD_VS1X_PROJ)     \
+       vs12\$(BROADWAYD_VS1X_PROJ)     \
+       vs14\$(BROADWAYD_VS1X_PROJ)     \
+       vs15\$(BROADWAYD_VS1X_PROJ)     \
+       vs16\$(BROADWAYD_VS1X_PROJ)     \
+       vs17\$(BROADWAYD_VS1X_PROJ)
+
+GTK3_BROADWAYD_VC1X_PROJ_FILTERS =     \
+       vs11\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
+       vs12\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
+       vs14\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
+       vs15\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
+       vs16\$(BROADWAYD_VS1X_PROJ_FILTERS)     \
+       vs17\$(BROADWAYD_VS1X_PROJ_FILTERS)
+
+GTK3_DEMO_VC1X_PROJS = \
+       vs10\$(DEMO_VS1X_PROJ)  \
+       vs11\$(DEMO_VS1X_PROJ)  \
+       vs12\$(DEMO_VS1X_PROJ)  \
+       vs14\$(DEMO_VS1X_PROJ)  \
+       vs15\$(DEMO_VS1X_PROJ)  \
+       vs16\$(DEMO_VS1X_PROJ)  \
+       vs17\$(DEMO_VS1X_PROJ)
+
+GTK3_DEMO_VC1X_PROJ_FILTERS =  \
+       vs11\$(DEMO_VS1X_PROJ_FILTERS)  \
+       vs12\$(DEMO_VS1X_PROJ_FILTERS)  \
+       vs14\$(DEMO_VS1X_PROJ_FILTERS)  \
+       vs15\$(DEMO_VS1X_PROJ_FILTERS)  \
+       vs16\$(DEMO_VS1X_PROJ_FILTERS)  \
+       vs17\$(DEMO_VS1X_PROJ_FILTERS)
+
+GTK3_GDK_WIN32_VCPROJS =       \
+       vs9\$(GDKWIN32_VS9_PROJ)        \
+       $(GTK3_GDK_WIN32_VC1X_PROJS)    \
+       $(GTK3_GDK_WIN32_VC1X_PROJ_FILTERS)
+
+GTK3_GDK_BROADWAY_VCPROJS =    \
+       vs9\$(GDKBROADWAY_VS9_PROJ)     \
+       $(GTK3_GDK_BROADWAY_VC1X_PROJS) \
+       $(GTK3_GDK_BROADWAY_VC1X_PROJ_FILTERS)
+
+GTK3_BROADWAYD_VCPROJS =       \
+       vs9\$(BROADWAYD_VS9_PROJ)       \
+       $(GTK3_BROADWAYD_VC1X_PROJS)    \
+       $(GTK3_BROADWAYD_VC1X_PROJ_FILTERS)
+
+GTK3_GDK_VCPROJS =     \
+       vs9\$(GDK_VS9_PROJ)     \
+       $(GTK3_GDK_VC1X_PROJS)  \
+       $(GTK3_GDK_VC1X_PROJ_FILTERS)   \
+       $(GTK3_GDK_WIN32_VCPROJS)       \
+       $(GTK3_GDK_BROADWAY_VCPROJS)    \
+       $(GTK3_BROADWAYD_VCPROJS)
+
+GTK3_GTK_VCPROJS =     \
+       vs9\$(GTK_VS9_PROJ)     \
+       $(GTK3_GTK_VC1X_PROJS)  \
+       $(GTK3_GTK_VC1X_PROJ_FILTERS)
+
+GTK3_GAILUTIL_VCPROJS =        \
+       vs9\$(GAILUTIL_VS9_PROJ)        \
+       $(GTK3_GAILUTIL_VC1X_PROJS)     \
+       $(GTK3_GAILUTIL_VC1X_PROJ_FILTERS)
+
+GTK3_DEMO_VCPROJS =    \
+       vs9\$(DEMO_VS9_PROJ)    \
+       $(GTK3_DEMO_VC1X_PROJS) \
+       $(GTK3_DEMO_VC1X_PROJ_FILTERS)
+
+DEMO_DEP_LIBS_NEW_PANGO=harfbuzz.lib
+DEMO_DEP_LIBS_PANGOFT2_VS1X=pangoft2-1.0.lib;harfbuzz.lib;freetype.lib
+DEMO_DEP_LIBS_PANGOFT2_VS9=$(DEMO_DEP_LIBS_PANGOFT2_VS1X:;= )
+
+# (Re-) generate Visual Studio projects
+# Dependencies for library projects
+gdk-3.sourcefiles      \
+gdk-3.vs10.sourcefiles \
+gdk-3.vs10.sourcefiles.filters: $(GDK_C_SRCS:/=\)
+
+gdk3-win32.sourcefiles \
+gdk3-win32.vs10.sourcefiles    \
+gdk3-win32.vs10.sourcefiles.filters: $(GDK_WIN32_C_SRCS)
+
+gdk3-broadway.sourcefiles      \
+gdk3-broadway.vs10.sourcefiles \
+gdk3-broadway.vs10.sourcefiles.filters: $(GDK_BROADWAY_C_SRCS)
+
+# GTK projects-Darn the fatal error U1095...!
+gtk-3.misc.sourcefiles \
+gtk-3.misc.vs10.sourcefiles    \
+gtk-3.misc.vs10.sourcefiles.filters: $(GTK_MISC_C_SRCS:/=\)
+
+gtk-3.a-h.sourcefiles  \
+gtk-3.a-h.vs10.sourcefiles     \
+gtk-3.a-h.vs10.sourcefiles.filters: $(GTK_C_SRCS_A_H:/=\)
+
+gtk-3.i-w.sourcefiles  \
+gtk-3.i-w.vs10.sourcefiles     \
+gtk-3.i-w.vs10.sourcefiles.filters: $(GTK_C_SRCS_I_W:/=\)
+
+gtk-3.win32.sourcefiles        \
+gtk-3.win32.vs10.sourcefiles   \
+gtk-3.win32.vs10.sourcefiles.filters: $(GTK_OS_WIN32_C_SRCS:/=\) $(GTK_MORE_C_SRCS)
+
+gtk-3.sourcefiles:     \
+       gtk-3.a-h.sourcefiles   \
+       gtk-3.i-w.sourcefiles   \
+       gtk-3.misc.sourcefiles  \
+       gtk-3.win32.sourcefiles
+
+gtk-3.vs10.sourcefiles:        \
+       gtk-3.a-h.vs10.sourcefiles      \
+       gtk-3.i-w.vs10.sourcefiles      \
+       gtk-3.misc.vs10.sourcefiles     \
+       gtk-3.win32.vs10.sourcefiles
+
+gtk-3.vs10.sourcefiles.filters:        \
+       gtk-3.a-h.vs10.sourcefiles.filters      \
+       gtk-3.i-w.vs10.sourcefiles.filters      \
+       gtk-3.misc.vs10.sourcefiles.filters     \
+       gtk-3.win32.vs10.sourcefiles.filters
+
+gtk-3.sourcefiles gtk-3.vs10.sourcefiles gtk-3.vs10.sourcefiles.filters:
+       @echo Genarating the final $@ from $**...
+       @for %%f in ($**) do @type %%f>>$@ & del %%f
+
+gailutil-3.sourcefiles \
+gailutil-3.vs10.sourcefiles    \
+gailutil-3.vs10.sourcefiles.filters: $(GAILUTIL_C_SRCS)
+
+# Dependencies for executable projects
+broadwayd.sourcefiles  \
+broadwayd.vs10.sourcefiles     \
+broadwayd.vs10.sourcefiles.filters: $(BROADWAYD_C_SRCS)
+
+gtk3-demo.sourcefiles  \
+gtk3-demo.vs10.sourcefiles     \
+gtk3-demo.vs10.sourcefiles.filters: $(demo_actual_sources) $(more_demo_sources)
+
+gdk-3.sourcefiles gdk3-win32.sourcefiles       \
+gdk3-broadway.sourcefiles gailutil-3.sourcefiles       \
+broadwayd.sourcefiles gtk3-demo.sourcefiles:
+       @-del vs9\$(@B).vcproj
+       @for %%s in ($**) do @echo.   ^<File RelativePath^="..\%%s" /^>>>$@
+
+gtk-3.a-h.sourcefiles gtk-3.i-w.sourcefiles    \
+gtk-3.misc.sourcefiles gtk-3.win32.sourcefiles:
+       @echo Generating $@...
+       @if exist vs9\$(GTK_VS9_PROJ) del vs9\$(GTK_VS9_PROJ)
+       @for %%s in ($(**:..\gtk\=)) do @echo.   ^<File RelativePath^="..\..\gtk\%%s" /^>>>$@
+
+gdk-3.vs10.sourcefiles \
+gdk3-win32.vs10.sourcefiles    \
+gdk3-broadway.vs10.sourcefiles \
+gailutil-3.vs10.sourcefiles    \
+broadwayd.vs10.sourcefiles     \
+gtk3-demo.vs10.sourcefiles:
+       @echo Generating $@...
+       @-del vs10\$(@B:.vs10=.vcxproj)
+       @for %%s in ($**) do @echo.   ^<ClCompile Include^="..\%%s" /^>>>$@
+
+gtk-3.a-h.vs10.sourcefiles     \
+gtk-3.i-w.vs10.sourcefiles     \
+gtk-3.misc.vs10.sourcefiles    \
+gtk-3.win32.vs10.sourcefiles:
+       @echo Generating $@...
+       @if exist vs10\$(GTK_VS1X_PROJ) del vs10\$(GTK_VS1X_PROJ)
+       @for %%s in ($(**:..\gtk\=)) do @echo.   ^<ClCompile Include^="..\..\gtk\%%s" /^>>>$@
+
+gdk-3.vs10.sourcefiles.filters \
+gdk3-win32.vs10.sourcefiles.filters    \
+gdk3-broadway.vs10.sourcefiles.filters \
+gailutil-3.vs10.sourcefiles.filters    \
+broadwayd.vs10.sourcefiles.filters     \
+gtk3-demo.vs10.sourcefiles.filters:
+       @-del vs10\$(@F:.vs10.sourcefiles=.vcxproj)
+       @for %%s in ($**) do @echo.   ^<ClCompile Include^="..\%%s"^>^<Filter^>Source 
Files^</Filter^>^</ClCompile^>>>$@
+
+gtk-3.a-h.vs10.sourcefiles.filters     \
+gtk-3.i-w.vs10.sourcefiles.filters     \
+gtk-3.misc.vs10.sourcefiles.filters    \
+gtk-3.win32.vs10.sourcefiles.filters:
+       @if exist vs10\$(GTK_VS1X_PROJ_FILTERS) del vs10\$(GTK_VS1X_PROJ_FILTERS)
+       @for %%s in ($(**:..\gtk\=)) do @echo.   ^<ClCompile Include^="..\..\gtk\%%s"^>^<Filter^>Source 
Files^</Filter^>^</ClCompile^>>>$@
+
+# Dependencies for GDK projects
+vs9\$(GDK_VS9_PROJ): gdk-3.sourcefiles vs9\$(GDK_VS9_PROJ)in
+vs9\$(GDKWIN32_VS9_PROJ).pre: gdk3-win32.sourcefiles vs9\$(GDKWIN32_VS9_PROJ)in
+vs9\$(GDKBROADWAY_VS9_PROJ): gdk3-broadway.sourcefiles vs9\$(GDKBROADWAY_VS9_PROJ)in
+vs9\$(GTK_VS9_PROJ): gtk-3.sourcefiles vs9\$(GTK_VS9_PROJ)in
+vs9\$(GAILUTIL_VS9_PROJ): gailutil-3.sourcefiles vs9\$(GAILUTIL_VS9_PROJ)in
+
+vs10\$(GDK_VS1X_PROJ): gdk-3.vs10.sourcefiles vs10\$(GDK_VS1X_PROJ)in
+vs10\$(GDKWIN32_VS1X_PROJ).pre: gdk3-win32.vs10.sourcefiles vs10\$(GDKWIN32_VS1X_PROJ)in
+vs10\$(GDKBROADWAY_VS1X_PROJ): gdk3-broadway.vs10.sourcefiles vs10\$(GDKBROADWAY_VS1X_PROJ)in
+vs10\$(GTK_VS1X_PROJ): gtk-3.vs10.sourcefiles vs10\$(GTK_VS1X_PROJ)in
+vs10\$(GAILUTIL_VS1X_PROJ): gailutil-3.vs10.sourcefiles vs10\$(GAILUTIL_VS1X_PROJ)in
+
+vs10\$(GDK_VS1X_PROJ_FILTERS): gdk-3.vs10.sourcefiles.filters vs10\$(GDK_VS1X_PROJ_FILTERS)in
+vs10\$(GDKWIN32_VS1X_PROJ_FILTERS): gdk3-win32.vs10.sourcefiles.filters vs10\$(GDKWIN32_VS1X_PROJ_FILTERS)in
+vs10\$(GDKBROADWAY_VS1X_PROJ_FILTERS): gdk3-broadway.vs10.sourcefiles.filters 
vs10\$(GDKBROADWAY_VS1X_PROJ_FILTERS)in
+vs10\$(GTK_VS1X_PROJ_FILTERS): gtk-3.vs10.sourcefiles.filters vs10\$(GTK_VS1X_PROJ_FILTERS)in
+vs10\$(GAILUTIL_VS1X_PROJ_FILTERS): gailutil-3.vs10.sourcefiles.filters vs10\$(GAILUTIL_VS1X_PROJ_FILTERS)in
+
+# Dependencies for tool executables
+vs9\$(BROADWAYD_VS9_PROJ): broadwayd.sourcefiles vs9\$(BROADWAYD_VS9_PROJ)in
+vs10\$(BROADWAYD_VS1X_PROJ): broadwayd.vs10.sourcefiles vs10\$(BROADWAYD_VS1X_PROJ)in
+vs10\$(BROADWAYD_VS1X_PROJ_FILTERS): broadwayd.vs10.sourcefiles.filters vs10\$(BROADWAYD_VS1X_PROJ_FILTERS)in
+
+# Dependencies for demos
+vs9\$(DEMO_VS9_PROJ).pre: gtk3-demo.sourcefiles vs9\$(DEMO_VS9_PROJ)in
+vs10\$(DEMO_VS1X_PROJ).pre: gtk3-demo.vs10.sourcefiles vs10\$(DEMO_VS1X_PROJ)in
+vs10\$(DEMO_VS1X_PROJ_FILTERS): gtk3-demo.vs10.sourcefiles.filters vs10\$(DEMO_VS1X_PROJ_FILTERS)in
+
+# Create the project files themselves without customization with options
+vs9\$(GDKWIN32_VS9_PROJ).pre   \
+vs9\$(GDKBROADWAY_VS9_PROJ)    \
+vs9\$(GDK_VS9_PROJ)    \
+vs9\$(GTK_VS9_PROJ)    \
+vs9\$(GAILUTIL_VS9_PROJ)       \
+vs9\$(BROADWAYD_VS9_PROJ)      \
+vs9\$(DEMO_VS9_PROJ).pre       \
+vs10\$(GDKWIN32_VS1X_PROJ).pre \
+vs10\$(GDKBROADWAY_VS1X_PROJ)  \
+vs10\$(GDK_VS1X_PROJ)  \
+vs10\$(GTK_VS1X_PROJ)  \
+vs10\$(GAILUTIL_VS1X_PROJ)     \
+vs10\$(BROADWAYD_VS1X_PROJ)    \
+vs10\$(DEMO_VS1X_PROJ).pre     \
+vs10\$(GDKWIN32_VS1X_PROJ_FILTERS)     \
+vs10\$(GDKBROADWAY_VS1X_PROJ_FILTERS)  \
+vs10\$(GDK_VS1X_PROJ_FILTERS)  \
+vs10\$(GTK_VS1X_PROJ_FILTERS)  \
+vs10\$(GAILUTIL_VS1X_PROJ_FILTERS)     \
+vs10\$(BROADWAYD_VS1X_PROJ_FILTERS)    \
+vs10\$(DEMO_VS1X_PROJ_FILTERS):
+       @$(CPP) /nologo /EP /I. $(@:.pre=)in>$(@F:.pre=).tmp
+       @for /f "usebackq tokens=* delims=" %%l in ($(@F:.pre=).tmp) do @echo %%l>>$@
+       @-del $(@F:.pre=).tmp
+       @-for %%f in ($**) do @if not "%%f" == "$(@:.pre=)in" del %%f
+
+vs9\$(GDKWIN32_VS9_PROJ): vs9\$(GDKWIN32_VS9_PROJ).pre
+vs10\$(GDKWIN32_VS1X_PROJ): vs10\$(GDKWIN32_VS1X_PROJ).pre
+
+vs9\$(DEMO_VS9_PROJ): vs9\$(DEMO_VS9_PROJ).pre
+vs10\$(DEMO_VS1X_PROJ): vs10\$(DEMO_VS1X_PROJ).pre
+
+!ifdef USE_EGL
+regenerate-gdk-vsproj-msg:
+       @echo Regenerating GDK Visual Studio projects with EGL support...
+
+vs9\$(GDKWIN32_VS9_PROJ):
+       @echo Generating $@...
+       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
+       --instring=";INSIDE_GDK_WIN32\""        \
+       --outstring=";INSIDE_GDK_WIN32;GDK_WIN32_ENABLE_EGL\""
+       @-del $**
+
+vs10\$(GDKWIN32_VS1X_PROJ):
+       @echo Generating $@...
+       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
+       --instring=";INSIDE_GDK_WIN32;%"        \
+       --outstring=";INSIDE_GDK_WIN32;GDK_WIN32_ENABLE_EGL;%"
+       @-del $**
+!else
+regenerate-gdk-vsproj-msg:
+       @echo Regenerating GDK Visual Studio projects without EGL support...
+
+vs9\$(GDKWIN32_VS9_PROJ) vs10\$(GDKWIN32_VS1X_PROJ):
+       @echo Renaming $** to $@...
+       @move $** $@
+!endif
+
+!ifdef FONT_FEATURES_DEMO
+!ifdef FONT_FEATURES_USE_PANGOFT2
+DEMO_MSG = with font features demo using PangoFT2
+vs9\$(DEMO_VS9_PROJ):
+       @echo (Re-)Generating $@ $(DEMO_MSG)...
+       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
+       --instring="AdditionalDependencies=\"\""        \
+       --outstring="AdditionalDependencies=\"$(DEMO_DEP_LIBS_PANGOFT2_VS9)\""
+       @-del $**
+
+vs10\$(DEMO_VS1X_PROJ):
+       @echo (Re-)Generating $@ $(DEMO_MSG)...
+       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
+       --instring=">%(AdditionalDependencies)<"        \
+       --outstring=">$(DEMO_DEP_LIBS_PANGOFT2_VS1X);%(AdditionalDependencies)<"
+       @-del $**
+!else
+DEMO_MSG = with font features demo
+vs9\$(DEMO_VS9_PROJ):
+       @echo (Re-)Generating $@ $(DEMO_MSG)...
+       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
+       --instring="AdditionalDependencies=\"\""        \
+       --outstring="AdditionalDependencies=\"$(DEMO_DEP_LIBS_NEW_PANGO)\""
+       @-del $**
+
+vs10\$(DEMO_VS1X_PROJ):
+       @echo (Re-)Generating $@ $(DEMO_MSG)...
+       @$(PYTHON) replace.py -a=replace-str -i=$** -o=$@       \
+       --instring=">%(AdditionalDependencies)<"        \
+       --outstring=">$(DEMO_DEP_LIBS_NEW_PANGO);%(AdditionalDependencies)<"
+       @-del $**
+!endif
+!else
+DEMO_MSG = without font features demo
+vs9\$(DEMO_VS9_PROJ) vs10\$(DEMO_VS1X_PROJ):
+       @echo (Re-)Generating $@ $(DEMO_MSG)...
+       @move $** $@
+!endif
+
+regenerate-demos-h-win32-msg:
+       @echo (Re-)Generating demos.h.win32 $(DEMO_MSG)...
+
+# VS2012+ .vcxproj: Update the toolset version as appropriate
+{vs10\}.vcxproj{vs11\}.vcxproj:
+       @echo Copying and updating $< for VS2012
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v110<"
+
+{vs10\}.vcxproj{vs12\}.vcxproj:
+       @echo Copying and updating $< for VS2013
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v120<"
+
+{vs10\}.vcxproj{vs14\}.vcxproj:
+       @echo Copying and updating $< for VS2015
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v140<"
+
+{vs10\}.vcxproj{vs15\}.vcxproj:
+       @echo Copying and updating $< for VS2017
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v141<"
+
+{vs10\}.vcxproj{vs16\}.vcxproj:
+       @echo Copying and updating $< for VS2019
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v142<"
+
+{vs10\}.vcxproj{vs17\}.vcxproj:
+       @echo Copying and updating $< for VS2022
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@ --instring=">v100<" --outstring=">v143<"
+
+# VS2012+ .vcxproj.filters: We simply copy the VS2010 ones
+{vs10\}.filters{vs11\}.filters:
+       @echo Copying $< to $@...
+       @copy $< $@
+
+{vs10\}.filters{vs12\}.filters:
+       @echo Copying $< to $@...
+       @copy $< $@
+
+{vs10\}.filters{vs14\}.filters:
+       @echo Copying $< to $@...
+       @copy $< $@
+
+{vs10\}.filters{vs15\}.filters:
+       @echo Copying $< to $@...
+       @copy $< $@
+
+{vs10\}.filters{vs16\}.filters:
+       @echo Copying $< to $@...
+       @copy $< $@
+
+{vs10\}.filters{vs17\}.filters:
+       @echo Copying $< to $@...
+       @copy $< $@
+
+{vs10\}.sln{vs11\}.sln:
+       @echo Copying and updating $< for VS2012...
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
+       --instring="Format Version 11.00" --outstring="Format Version 12.00"
+       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
+       --instring="# Visual Studio 2010" --outstring="# Visual Studio 2012"
+       @del $@.tmp
+
+{vs10\}.sln{vs12\}.sln:
+       @echo Copying and updating $< for VS2013...
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
+       --instring="Format Version 11.00" --outstring="Format Version 12.00"
+       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
+       --instring="# Visual Studio 2010" --outstring="# Visual Studio 2013"
+       @del $@.tmp
+
+{vs10\}.sln{vs14\}.sln:
+       @echo Copying and updating $< for VS2015...
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
+       --instring="Format Version 11.00" --outstring="Format Version 12.00"
+       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
+       --instring="# Visual Studio 2010" --outstring="# Visual Studio 14"
+       @del $@.tmp
+
+{vs10\}.sln{vs15\}.sln:
+       @echo Copying and updating $< for VS2017...
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
+       --instring="Format Version 11.00" --outstring="Format Version 12.00"
+       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
+       --instring="# Visual Studio 2010" --outstring="# Visual Studio 15"
+       @del $@.tmp
+
+{vs10\}.sln{vs16\}.sln:
+       @echo Copying and updating $< for VS2019...
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
+       --instring="Format Version 11.00" --outstring="Format Version 12.00"
+       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
+       --instring="# Visual Studio 2010" --outstring="# Visual Studio 16"
+       @del $@.tmp
+
+{vs10\}.sln{vs17\}.sln:
+       @echo Copying and updating $< for VS2022...
+       @$(PYTHON) replace.py -a=replace-str -i=$< -o=$@.tmp    \
+       --instring="Format Version 11.00" --outstring="Format Version 12.00"
+       @$(PYTHON) replace.py -a=replace-str -i=$@.tmp -o=$@    \
+       --instring="# Visual Studio 2010" --outstring="# Visual Studio 17"
+       @del $@.tmp
+
+copy-update-static-projects:   \
+$(GTK3_VS11_STATIC_PROJS)      \
+$(GTK3_VS12_STATIC_PROJS)      \
+$(GTK3_VS14_STATIC_PROJS)      \
+$(GTK3_VS15_STATIC_PROJS)      \
+$(GTK3_VS16_STATIC_PROJS)      \
+$(GTK3_VS17_STATIC_PROJS)
+
+regenerate-gtk-vsproj-msg:
+       @echo Regenerating GTK and gailutil projects...
+
+regenerate-gdk-vsproj: regenerate-gdk-vsproj-msg $(GTK3_GDK_VCPROJS)
+regenerate-gtk-vsproj: regenerate-gtk-vsproj-msg $(GTK3_GTK_VCPROJS) $(GTK3_GAILUTIL_VCPROJS)
+
+regenerate-all-msvc-projs:     \
+       copy-update-static-projects     \
+       regenerate-gdk-vsproj   \
+       regenerate-gtk-vsproj   \
+       regenerate-demos-h-win32
+
+.SUFFIXES: .vcxproj .filters .sln


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]