Merge branch 'maint'
authorJunio C Hamano <junkio@cox.net>
Wed, 13 Dec 2006 01:07:33 +0000 (17:07 -0800)
committerJunio C Hamano <junkio@cox.net>
Wed, 13 Dec 2006 01:07:33 +0000 (17:07 -0800)
* maint:
Clarify fetch error for missing objects.
Move Fink and Ports check to after config file

Conflicts:

Makefile

1  2 
Makefile
diff --combined Makefile
index a1861de2cc835cff1d72322bc6510abb1e32c529,c5a180490b0fbb6bae8a9a2a87c3795c89391c2f..906e98492080d2fde9467a9970fc92d7a8cfeaf8
+++ b/Makefile
@@@ -69,6 -69,8 +69,6 @@@ all
  #
  # Define NO_MMAP if you want to avoid mmap.
  #
 -# Define WITH_OWN_SUBPROCESS_PY if you want to use with python 2.3.
 -#
  # Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
  #
  # Define NO_SOCKADDR_STORAGE if your platform does not have struct
  #
  # Define USE_STDEV below if you want git to care about the underlying device
  # change being considered an inode change from the update-cache perspective.
 +#
 +# Define NO_PERL_MAKEMAKER if you cannot use Makefiles generated by perl's
 +# MakeMaker (e.g. using ActiveState under Cygwin).
 +#
  
  GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE
        @$(SHELL_PATH) ./GIT-VERSION-GEN
@@@ -118,6 -116,7 +118,6 @@@ prefix = $(HOME
  bindir = $(prefix)/bin
  gitexecdir = $(bindir)
  template_dir = $(prefix)/share/git-core/templates/
 -GIT_PYTHON_DIR = $(prefix)/share/git-core/python
  # DESTDIR=
  
  # default configuration for gitweb
@@@ -136,7 -135,7 +136,7 @@@ GITWEB_FAVICON = git-favicon.pn
  GITWEB_SITE_HEADER =
  GITWEB_SITE_FOOTER =
  
 -export prefix bindir gitexecdir template_dir GIT_PYTHON_DIR
 +export prefix bindir gitexecdir template_dir
  
  CC = gcc
  AR = ar
@@@ -175,13 -174,17 +175,13 @@@ SCRIPT_SH = 
  
  SCRIPT_PERL = \
        git-archimport.perl git-cvsimport.perl git-relink.perl \
 -      git-shortlog.perl git-rerere.perl \
 +      git-rerere.perl \
        git-cvsserver.perl \
        git-svnimport.perl git-cvsexportcommit.perl \
        git-send-email.perl git-svn.perl
  
 -SCRIPT_PYTHON = \
 -      git-merge-recursive-old.py
 -
  SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \
          $(patsubst %.perl,%,$(SCRIPT_PERL)) \
 -        $(patsubst %.py,%,$(SCRIPT_PYTHON)) \
          git-cherry-pick git-status git-instaweb
  
  # ... and all the rest that could be moved out of bindir to gitexecdir
@@@ -224,6 -227,12 +224,6 @@@ endi
  ifndef PERL_PATH
        PERL_PATH = /usr/bin/perl
  endif
 -ifndef PYTHON_PATH
 -      PYTHON_PATH = /usr/bin/python
 -endif
 -
 -PYMODULES = \
 -      gitMergeCommon.py
  
  LIB_FILE=libgit.a
  XDIFF_LIB=xdiff/lib.a
@@@ -291,7 -300,6 +291,7 @@@ BUILTIN_OBJS = 
        builtin-rev-parse.o \
        builtin-rm.o \
        builtin-runstatus.o \
 +      builtin-shortlog.o \
        builtin-show-branch.o \
        builtin-stripspace.o \
        builtin-symbolic-ref.o \
@@@ -326,18 -334,6 +326,6 @@@ ifeq ($(uname_S),Darwin
        NEEDS_SSL_WITH_CRYPTO = YesPlease
        NEEDS_LIBICONV = YesPlease
        NO_STRLCPY = YesPlease
-       ifndef NO_FINK
-               ifeq ($(shell test -d /sw/lib && echo y),y)
-                       BASIC_CFLAGS += -I/sw/include
-                       BASIC_LDFLAGS += -L/sw/lib
-               endif
-       endif
-       ifndef NO_DARWIN_PORTS
-               ifeq ($(shell test -d /opt/local/lib && echo y),y)
-                       BASIC_CFLAGS += -I/opt/local/include
-                       BASIC_LDFLAGS += -L/opt/local/lib
-               endif
-       endif
  endif
  ifeq ($(uname_S),SunOS)
        NEEDS_SOCKET = YesPlease
@@@ -415,6 -411,31 +403,21 @@@ endi
  -include config.mak.autogen
  -include config.mak
  
 -ifdef WITH_OWN_SUBPROCESS_PY
 -      PYMODULES += compat/subprocess.py
 -else
 -      ifeq ($(NO_PYTHON),)
 -              ifneq ($(shell $(PYTHON_PATH) -c 'import subprocess;print"OK"' 2>/dev/null),OK)
 -                      PYMODULES += compat/subprocess.py
 -              endif
 -      endif
 -endif
 -
+ ifeq ($(uname_S),Darwin)
+       ifndef NO_FINK
+               ifeq ($(shell test -d /sw/lib && echo y),y)
+                       BASIC_CFLAGS += -I/sw/include
+                       BASIC_LDFLAGS += -L/sw/lib
+               endif
+       endif
+       ifndef NO_DARWIN_PORTS
+               ifeq ($(shell test -d /opt/local/lib && echo y),y)
+                       BASIC_CFLAGS += -I/opt/local/include
+                       BASIC_LDFLAGS += -L/opt/local/lib
+               endif
+       endif
+ endif
  ifndef NO_CURL
        ifdef CURLDIR
                # This is still problematic -- gcc does not always want -R.
@@@ -543,9 -564,6 +546,9 @@@ endi
  ifdef NO_ACCURATE_DIFF
        BASIC_CFLAGS += -DNO_ACCURATE_DIFF
  endif
 +ifdef NO_PERL_MAKEMAKER
 +      export NO_PERL_MAKEMAKER
 +endif
  
  # Shell quote (do not use $(call) to accommodate ancient setups);
  
@@@ -559,6 -577,8 +562,6 @@@ prefix_SQ = $(subst ','\'',$(prefix)
  
  SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
  PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH))
 -PYTHON_PATH_SQ = $(subst ','\'',$(PYTHON_PATH))
 -GIT_PYTHON_DIR_SQ = $(subst ','\'',$(GIT_PYTHON_DIR))
  
  LIBS = $(GITLIBS) $(EXTLIBS)
  
@@@ -575,8 -595,8 +578,8 @@@ export prefix TAR INSTALL DESTDIR SHELL
  
  all: $(ALL_PROGRAMS) $(BUILT_INS) git$X gitk gitweb/gitweb.cgi
  
 -all: perl/Makefile
 -      $(MAKE) -C perl
 +all:
 +      $(MAKE) -C perl PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' all
        $(MAKE) -C templates
  
  strip: $(PROGRAMS) git$X
@@@ -605,15 -625,12 +608,15 @@@ $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %
            -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
            -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
            -e 's/@@NO_CURL@@/$(NO_CURL)/g' \
 -          -e 's/@@NO_PYTHON@@/$(NO_PYTHON)/g' \
            $@.sh >$@+
        chmod +x $@+
        mv $@+ $@
  
 -$(patsubst %.perl,%,$(SCRIPT_PERL)): perl/Makefile
 +$(patsubst %.perl,%,$(SCRIPT_PERL)): perl/perl.mak
 +
 +perl/perl.mak: GIT-CFLAGS
 +      $(MAKE) -C perl PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' $(@F)
 +
  $(patsubst %.perl,%,$(SCRIPT_PERL)): % : %.perl
        rm -f $@ $@+
        INSTLIBDIR=`$(MAKE) -C perl -s --no-print-directory instlibdir` && \
        chmod +x $@+
        mv $@+ $@
  
 -$(patsubst %.py,%,$(SCRIPT_PYTHON)) : % : %.py GIT-CFLAGS
 -      rm -f $@ $@+
 -      sed -e '1s|#!.*python|#!$(PYTHON_PATH_SQ)|' \
 -          -e 's|@@GIT_PYTHON_PATH@@|$(GIT_PYTHON_DIR_SQ)|g' \
 -          -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
 -          $@.py >$@+
 -      chmod +x $@+
 -      mv $@+ $@
 -
  git-cherry-pick: git-revert
        cp $< $@+
        mv $@+ $@
@@@ -666,6 -692,7 +669,6 @@@ git-instaweb: git-instaweb.sh gitweb/gi
        sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
            -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
            -e 's/@@NO_CURL@@/$(NO_CURL)/g' \
 -          -e 's/@@NO_PYTHON@@/$(NO_PYTHON)/g' \
            -e '/@@GITWEB_CGI@@/r gitweb/gitweb.cgi' \
            -e '/@@GITWEB_CGI@@/d' \
            -e '/@@GITWEB_CSS@@/r gitweb/gitweb.css' \
@@@ -685,6 -712,7 +688,6 @@@ configure: configure.a
  git$X git.spec \
        $(patsubst %.sh,%,$(SCRIPT_SH)) \
        $(patsubst %.perl,%,$(SCRIPT_PERL)) \
 -      $(patsubst %.py,%,$(SCRIPT_PYTHON)) \
        : GIT-VERSION-FILE
  
  %.o: %.c GIT-CFLAGS
@@@ -758,7 -786,7 +761,7 @@@ tags
        find . -name '*.[hcS]' -print | xargs ctags -a
  
  ### Detect prefix changes
 -TRACK_CFLAGS = $(subst ','\'',$(ALL_CFLAGS)):$(GIT_PYTHON_DIR_SQ):\
 +TRACK_CFLAGS = $(subst ','\'',$(ALL_CFLAGS)):\
               $(bindir_SQ):$(gitexecdir_SQ):$(template_dir_SQ):$(prefix_SQ)
  
  GIT-CFLAGS: .FORCE-GIT-CFLAGS
  # However, the environment gets quite big, and some programs have problems
  # with that.
  
 -export NO_PYTHON
  export NO_SVN_TESTS
  
  test: all
@@@ -807,7 -836,9 +810,7 @@@ install: al
        $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexecdir_SQ)'
        $(INSTALL) git$X gitk '$(DESTDIR_SQ)$(bindir_SQ)'
        $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install
 -      $(MAKE) -C perl install
 -      $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(GIT_PYTHON_DIR_SQ)'
 -      $(INSTALL) $(PYMODULES) '$(DESTDIR_SQ)$(GIT_PYTHON_DIR_SQ)'
 +      $(MAKE) -C perl prefix='$(prefix_SQ)' install
        if test 'z$(bindir_SQ)' != 'z$(gitexecdir_SQ)'; \
        then \
                ln -f '$(DESTDIR_SQ)$(bindir_SQ)/git$X' \
@@@ -877,7 -908,8 +880,7 @@@ clean
        rm -f $(htmldocs).tar.gz $(manpages).tar.gz
        rm -f gitweb/gitweb.cgi
        $(MAKE) -C Documentation/ clean
 -      [ ! -f perl/Makefile ] || $(MAKE) -C perl/ clean || $(MAKE) -C perl/ clean
 -      rm -f perl/ppport.h perl/Makefile.old
 +      $(MAKE) -C perl clean
        $(MAKE) -C templates/ clean
        $(MAKE) -C t/ clean
        rm -f GIT-VERSION-FILE GIT-CFLAGS
@@@ -893,6 -925,7 +896,6 @@@ check-docs:
                case "$$v" in \
                git-merge-octopus | git-merge-ours | git-merge-recursive | \
                git-merge-resolve | git-merge-stupid | git-merge-recur | \
 -              git-merge-recursive-old | \
                git-ssh-pull | git-ssh-push ) continue ;; \
                esac ; \
                test -f "Documentation/$$v.txt" || \