@@ -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
@@ -659,3 +661,77 @@ ifeq ($(uname_S),QNX)
659
661
NO_STRCASESTR = YesPlease
660
662
NO_STRLCPY = YesPlease
661
663
endif
664
+
665
+ vcxproj:
666
+ # Require clean work tree
667
+ git update-index -q --refresh && \
668
+ git diff-files --quiet && \
669
+ git diff-index --cached --quiet HEAD --
670
+
671
+ # Make .vcxproj files and add them
672
+ unset QUIET_GEN QUIET_BUILT_IN; \
673
+ perl contrib/buildsystems/generate -g Vcxproj
674
+ git add -f git.sln {*,*/lib,t/helper/*}/*.vcxproj
675
+
676
+ # Generate the LinkOrCopyBuiltins.targets file
677
+ (echo '<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">' && \
678
+ echo ' <Target Name="CopyBuiltins_AfterBuild" AfterTargets="AfterBuild">' && \
679
+ for name in $(BUILT_INS);\
680
+ do \
681
+ echo ' <Copy SourceFiles="$$(OutDir)\git.exe" DestinationFiles="$$(OutDir)\'"$$name"'" SkipUnchangedFiles="true" UseHardlinksIfPossible="true" />'; \
682
+ done && \
683
+ for name in $(REMOTE_CURL_ALIASES); \
684
+ do \
685
+ echo ' <Copy SourceFiles="$$(OutDir)\'"$(REMOTE_CURL_PRIMARY)"'" DestinationFiles="$$(OutDir)\'"$$name"'" SkipUnchangedFiles="true" UseHardlinksIfPossible="true" />'; \
686
+ done && \
687
+ echo ' </Target>' && \
688
+ echo '</Project>') >git/LinkOrCopyBuiltins.targets
689
+ git add -f git/LinkOrCopyBuiltins.targets
690
+
691
+ # Add command-list.h
692
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 command-list.h
693
+ git add -f command-list.h
694
+
695
+ # Add scripts
696
+ rm -f perl/perl.mak
697
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 \
698
+ $(SCRIPT_LIB) $(SCRIPT_SH_GEN) $(SCRIPT_PERL_GEN)
699
+ # Strip out the sane tool path, needed only for building
700
+ sed -i '/^git_broken_path_fix ".*/d' git-sh-setup
701
+ git add -f $(SCRIPT_LIB) $(SCRIPT_SH_GEN) $(SCRIPT_PERL_GEN)
702
+
703
+ # Add Perl module
704
+ $(MAKE) $(LIB_PERL_GEN)
705
+ git add -f perl/build
706
+
707
+ # Add bin-wrappers, for testing
708
+ rm -rf bin-wrappers/
709
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 $(test_bindir_programs)
710
+ # Ensure that the GIT_EXEC_PATH is a Unix-y one, and that the absolute
711
+ # path of the repository is not hard-coded (GIT_EXEC_PATH will be set
712
+ # by test-lib.sh according to the current setup)
713
+ sed -i -e 's/^\(GIT_EXEC_PATH\)=.*/test -n "$${\1##*:*}" ||\
714
+ \1="$$(cygpath -u "$$\1")"/' \
715
+ -e "s|'$$(pwd)|\"\$$GIT_EXEC_PATH\"'|g" bin-wrappers/*
716
+ # Ensure that test-* helpers find the .dll files copied to top-level
717
+ sed -i 's|^PATH=.*|&:"$$GIT_EXEC_PATH"|' bin-wrappers/test-*
718
+ # We do not want to force hard-linking builtins
719
+ sed -i 's|\(git\)-\([-a-z]*\)\.exe"|\1.exe" \2|g' \
720
+ bin-wrappers/git-{receive-pack,upload-archive}
721
+ git add -f $(test_bindir_programs)
722
+ # remote-ext is a builtin, but invoked as if it were external
723
+ sed 's|receive-pack|remote-ext|g' \
724
+ <bin-wrappers/git-receive-pack >bin-wrappers/git-remote-ext
725
+ git add -f bin-wrappers/git-remote-ext
726
+
727
+ # Add templates
728
+ $(MAKE) -C templates
729
+ git add -f templates/boilerplates.made templates/blt/
730
+
731
+ # Add build options
732
+ $(MAKE) MSVC=1 SKIP_VCPKG=1 prefix=/mingw64 GIT-BUILD-OPTIONS
733
+ git add -f GIT-BUILD-OPTIONS
734
+
735
+ # Commit the whole shebang
736
+ git commit -m "Generate Visual Studio solution" \
737
+ -m "Auto-generated by \`$(MAKE)$(MAKEFLAGS) $@\`"
0 commit comments