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