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