@@ -25,10 +25,12 @@ include compat/vcbuild/MSVC-DEFS-GEN
25
25
# See if vcpkg and the vcpkg-build versions of the third-party
26
26
# libraries that we use are installed. We include the result
27
27
# to get $(vcpkg_*) variables defined for the Makefile.
28
+ ifeq (,$(SKIP_VCPKG))
28
29
compat/vcbuild/VCPKG-DEFS: compat/vcbuild/vcpkg_install.bat
29
30
@"$<"
30
31
include compat/vcbuild/VCPKG-DEFS
31
32
endif
33
+ endif
32
34
33
35
# We choose to avoid "if .. else if .. else .. endif endif"
34
36
# because maintaining the nesting to match is a pain. If
@@ -680,3 +682,77 @@ ifeq ($(uname_S),QNX)
680
682
NO_STRCASESTR = YesPlease
681
683
NO_STRLCPY = YesPlease
682
684
endif
685
+
686
+ vcxproj:
687
+ # Require clean work tree
688
+ git update-index -q --refresh && \
689
+ git diff-files --quiet && \
690
+ git diff-index --cached --quiet HEAD --
691
+
692
+ # Make .vcxproj files and add them
693
+ unset QUIET_GEN QUIET_BUILT_IN; \
694
+ perl contrib/buildsystems/generate -g Vcxproj
695
+ git add -f git.sln {*,*/lib,t/helper/*}/*.vcxproj
696
+
697
+ # Generate the LinkOrCopyBuiltins.targets file
698
+ (echo '<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">' && \
699
+ echo ' <Target Name="CopyBuiltins_AfterBuild" AfterTargets="AfterBuild">' && \
700
+ for name in $(BUILT_INS);\
701
+ do \
702
+ echo ' <Copy SourceFiles="$$(OutDir)\git.exe" DestinationFiles="$$(OutDir)\'"$$name"'" SkipUnchangedFiles="true" UseHardlinksIfPossible="true" />'; \
703
+ done && \
704
+ for name in $(REMOTE_CURL_ALIASES); \
705
+ do \
706
+ echo ' <Copy SourceFiles="$$(OutDir)\'"$(REMOTE_CURL_PRIMARY)"'" DestinationFiles="$$(OutDir)\'"$$name"'" SkipUnchangedFiles="true" UseHardlinksIfPossible="true" />'; \
707
+ done && \
708
+ echo ' </Target>' && \
709
+ echo '</Project>') >git/LinkOrCopyBuiltins.targets
710
+ git add -f git/LinkOrCopyBuiltins.targets
711
+
712
+ # Add command-list.h
713
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 command-list.h
714
+ git add -f command-list.h
715
+
716
+ # Add scripts
717
+ rm -f perl/perl.mak
718
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 \
719
+ $(SCRIPT_LIB) $(SCRIPT_SH_GEN) $(SCRIPT_PERL_GEN)
720
+ # Strip out the sane tool path, needed only for building
721
+ sed -i '/^git_broken_path_fix ".*/d' git-sh-setup
722
+ git add -f $(SCRIPT_LIB) $(SCRIPT_SH_GEN) $(SCRIPT_PERL_GEN)
723
+
724
+ # Add Perl module
725
+ $(MAKE) $(LIB_PERL_GEN)
726
+ git add -f perl/build
727
+
728
+ # Add bin-wrappers, for testing
729
+ rm -rf bin-wrappers/
730
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 $(test_bindir_programs)
731
+ # Ensure that the GIT_EXEC_PATH is a Unix-y one, and that the absolute
732
+ # path of the repository is not hard-coded (GIT_EXEC_PATH will be set
733
+ # by test-lib.sh according to the current setup)
734
+ sed -i -e 's/^\(GIT_EXEC_PATH\)=.*/test -n "$${\1##*:*}" ||\
735
+ \1="$$(cygpath -u "$$\1")"/' \
736
+ -e "s|'$$(pwd)|\"\$$GIT_EXEC_PATH\"'|g" bin-wrappers/*
737
+ # Ensure that test-* helpers find the .dll files copied to top-level
738
+ sed -i 's|^PATH=.*|&:"$$GIT_EXEC_PATH"|' bin-wrappers/test-*
739
+ # We do not want to force hard-linking builtins
740
+ sed -i 's|\(git\)-\([-a-z]*\)\.exe"|\1.exe" \2|g' \
741
+ bin-wrappers/git-{receive-pack,upload-archive}
742
+ git add -f $(test_bindir_programs)
743
+ # remote-ext is a builtin, but invoked as if it were external
744
+ sed 's|receive-pack|remote-ext|g' \
745
+ <bin-wrappers/git-receive-pack >bin-wrappers/git-remote-ext
746
+ git add -f bin-wrappers/git-remote-ext
747
+
748
+ # Add templates
749
+ $(MAKE) -C templates
750
+ git add -f templates/boilerplates.made templates/blt/
751
+
752
+ # Add build options
753
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 GIT-BUILD-OPTIONS
754
+ git add -f GIT-BUILD-OPTIONS
755
+
756
+ # Commit the whole shebang
757
+ git commit -m "Generate Visual Studio solution" \
758
+ -m "Auto-generated by \`$(MAKE)$(MAKEFLAGS) $@\`"
0 commit comments