diff options
author | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2001-01-24 17:11:43 (GMT) |
---|---|---|
committer | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2001-01-24 17:11:43 (GMT) |
commit | 85515ad9795ffc3b676cbddeeea2b003818a2623 (patch) | |
tree | 03d17dc629135d7a52e7b8922bc33b65f03a9e04 | |
parent | 0bbaa515a1ae2e45debaf41ca72cc872fcba650e (diff) | |
download | cpython-85515ad9795ffc3b676cbddeeea2b003818a2623.zip cpython-85515ad9795ffc3b676cbddeeea2b003818a2623.tar.gz cpython-85515ad9795ffc3b676cbddeeea2b003818a2623.tar.bz2 |
Flat makefile based on toplevel Makefile.in and makefiles in build
subdirectories. Those other makefiles will go away eventually.
-rw-r--r-- | Makefile.pre.in | 814 |
1 files changed, 814 insertions, 0 deletions
diff --git a/Makefile.pre.in b/Makefile.pre.in new file mode 100644 index 0000000..cd5436f --- /dev/null +++ b/Makefile.pre.in @@ -0,0 +1,814 @@ +# Top-level Makefile for Python +# +# As distributed, this file is called Makefile.pre.in; it is processed +# into the real Makefile by running the script ./configure, which +# replaces things like @spam@ with values appropriate for your system. +# This means that if you edit Makefile, your changes get lost the next +# time you run the configure script. Ideally, you can do: +# +# ./configure +# make +# make test +# make install +# +# If you have a previous version of Python installed that you don't +# want to overwrite, you can use "make altinstall" instead of "make +# install". This changes the install procedure so it installs the +# Python binary as "python<version>". The libraries and include files +# are always installed in a subdirectory called "python<version>". +# "make altinstall" does not install the manual page. If you want to +# make this installation the "official" installation but want to keep +# the old binary around "just in case", rename the installed python +# binary to "python<oldversion>" before running "make install". +# (This only works between different versions, e.g. 1.3 and 1.4 -- +# different betas of the same version will overwrite each other in +# installation unless you override the VERSION Make variable.) +# +# In fact, "make install" or "make bininstall" installs the binary +# as python<version> and makes a hard link to python, so when +# installing a new version in the future, nothing of the current +# version will be lost (except for the man page). +# +# See also the section "Build instructions" in the README file. + +# === Variables set by makesetup === + +MODOBJS= _MODOBJS_ +MODLIBS= _MODLIBS_ + +# === Variables set by configure +VERSION= @VERSION@ +srcdir= @srcdir@ +VPATH= @srcdir@ + +CC= @CC@ +CXX= @CXX@ +LINKCC= @LINKCC@ +AR= @AR@ +RANLIB= @RANLIB@ + +# Shell used by make (some versions default to the login shell, which is bad) +SHELL= /bin/sh + +# Use this to make a link between python$(VERSION) and python in $(BINDIR) +LN= @LN@ + +# Portable install script (configure doesn't always guess right) +INSTALL= @INSTALL@ +INSTALL_PROGRAM=@INSTALL_PROGRAM@ +INSTALL_DATA= @INSTALL_DATA@ +# Shared libraries must be installed with executable mode on some systems; +# rather than figuring out exactly which, we always give them executable mode. +# Also, making them read-only seems to be a good idea... +INSTALL_SHARED= ${INSTALL} -m 555 + +MAKESETUP= $(srcdir)/Modules/makesetup + +# Compiler options +OPT= @OPT@ +DEFS= @DEFS@ +CFLAGS= $(OPT) -I. -I$(srcdir)/Include $(DEFS) +LDFLAGS= @LDFLAGS@ +LDLAST= @LDLAST@ +SGI_ABI= @SGI_ABI@ + +# Machine-dependent subdirectories +MACHDEP= @MACHDEP@ + +# Install prefix for architecture-independent files +prefix= @prefix@ + +# Install prefix for architecture-dependent files +exec_prefix= @exec_prefix@ + +# Expanded directories +BINDIR= $(exec_prefix)/bin +LIBDIR= $(exec_prefix)/lib +MANDIR= $(prefix)/man +INCLUDEDIR= $(prefix)/include +CONFINCLUDEDIR= $(exec_prefix)/include +SCRIPTDIR= $(prefix)/lib + +# Detailed destination directories +BINLIBDEST= $(LIBDIR)/python$(VERSION) +LIBDEST= $(SCRIPTDIR)/python$(VERSION) +INCLUDEPY= $(INCLUDEDIR)/python$(VERSION) +CONFINCLUDEPY= $(CONFINCLUDEDIR)/python$(VERSION) +LIBP= $(LIBDIR)/python$(VERSION) + +# Symbols used for using shared libraries +SO= @SO@ +LDSHARED= @LDSHARED@ +CCSHARED= @CCSHARED@ +LINKFORSHARED= @LINKFORSHARED@ +DESTSHARED= $(BINLIBDEST)/lib-dynload + +# Executable suffix (.exe on Windows and Mac OS X) +EXEEXT= @EXEEXT@ + +# Modes for directories, executables and data files created by the +# install process. Default to user-only-writable for all file types. +DIRMODE= 755 +EXEMODE= 755 +FILEMODE= 644 + +# --with-PACKAGE options for configure script +# e.g. --with-readline --with-svr5 --with-solaris --with-thread +# (see README for an explanation) +WITH= + + +# Subdirectories with code +SRCDIRS= @SRCDIRS@ + +# Other subdirectories +SUBDIRSTOO= Include Lib Misc Demo + +# Files and directories to be distributed +CONFIGFILES= configure configure.in acconfig.h config.h.in Makefile.pre.in +DISTFILES= README ChangeLog $(CONFIGFILES) +DISTDIRS= $(SUBDIRS) $(SUBDIRSTOO) Ext-dummy +DIST= $(DISTFILES) $(DISTDIRS) + + +LIBRARY= libpython$(VERSION).a +LDLIBRARY= @LDLIBRARY@ +DLLLIBRARY= @DLLLIBRARY@ + + +LIBS= @LIBS@ +LIBM= @LIBM@ +LIBC= @LIBC@ +SYSLIBS= $(LIBM) $(LIBC) + +MAINOBJ= @MAINOBJ@ +LIBOBJS= @LIBOBJS@ +DLINCLDIR= @DLINCLDIR@ +DYNLOADFILE= @DYNLOADFILE@ + +PYTHON= python$(EXEEXT) + +# === Definitions added by makesetup === + + +########################################################################## +# Modules +MODULE_OBJS= \ + Modules/config.o \ + Modules/getpath.o \ + Modules/main.o \ + Modules/getbuildinfo.o + +# Used of signalmodule.o is not available +SIGNAL_OBJS= @SIGNAL_OBJS@ + + +########################################################################## +# Grammar +GRAMMAR_H= $(srcdir)/Include/graminit.h +GRAMMAR_C= $(srcdir)/Python/graminit.c +GRAMMAR_INPUT= $(srcdir)/Grammar/Grammar + + +########################################################################## +# Parser +PGEN= Parser/pgen$(EXEEXT) + +POBJS= \ + Parser/acceler.o \ + Parser/grammar1.o \ + Parser/listnode.o \ + Parser/node.o \ + Parser/parser.o \ + Parser/parsetok.o \ + Parser/tokenizer.o \ + Parser/bitset.o \ + Parser/metagrammar.o + +PARSER_OBJS= $(POBJS) Parser/myreadline.o + +PGOBJS= \ + Parser/firstsets.o \ + Parser/grammar.o \ + Parser/pgen.o \ + Parser/printgrammar.o \ + Parser/pgenmain.o + +PGENOBJS= $(PGENMAIN) $(POBJS) $(PGOBJS) + + +########################################################################## +# Python +PYTHON_OBJS= \ + Python/bltinmodule.o \ + Python/exceptions.o \ + Python/ceval.o \ + Python/compile.o \ + Python/codecs.o \ + Python/errors.o \ + Python/frozen.o \ + Python/frozenmain.o \ + Python/getargs.o \ + Python/getcompiler.o \ + Python/getcopyright.o \ + Python/getmtime.o \ + Python/getplatform.o \ + Python/getversion.o \ + Python/graminit.o \ + Python/import.o \ + Python/importdl.o \ + Python/marshal.o \ + Python/modsupport.o \ + Python/mystrtoul.o \ + Python/pyfpe.o \ + Python/pystate.o \ + Python/pythonrun.o \ + Python/structmember.o \ + Python/sysmodule.o \ + Python/traceback.o \ + Python/getopt.o \ + Python/$(DYNLOADFILE) \ + $(LIBOBJS) + + +########################################################################## +# Objects +OBJECT_OBJS= \ + Objects/abstract.o \ + Objects/bufferobject.o \ + Objects/classobject.o \ + Objects/cobject.o \ + Objects/complexobject.o \ + Objects/fileobject.o \ + Objects/floatobject.o \ + Objects/frameobject.o \ + Objects/funcobject.o \ + Objects/intobject.o \ + Objects/listobject.o \ + Objects/longobject.o \ + Objects/dictobject.o \ + Objects/methodobject.o \ + Objects/moduleobject.o \ + Objects/object.o \ + Objects/rangeobject.o \ + Objects/sliceobject.o \ + Objects/stringobject.o \ + Objects/tupleobject.o \ + Objects/typeobject.o \ + Objects/unicodeobject.o \ + Objects/unicodectype.o + + +########################################################################## +# objects that get linked into the Python library +LIBRARY_OBJS= \ + $(PARSER_OBJS) \ + $(OBJECT_OBJS) \ + $(PYTHON_OBJS) \ + $(MODULE_OBJS) \ + $(SIGNAL_OBJS) \ + $(MODOBJS) + + +######################################################################### +# Rules + +# Default target +all: $(PYTHON) sharedmods + +# Build the interpreter +$(PYTHON): $(MAINOBJ) $(LDLIBRARY) + expr `cat buildno` + 1 >buildno1 + mv -f buildno1 buildno + $(LINKCC) $(LDFLAGS) $(LINKFORSHARED) -o $@ $(MAINOBJ) \ + $(LDLIBRARY) $(LIBS) $(MODLIBS) $(SYSLIBS) $(LDLAST) + +buildno: + echo 1 >buildno + +platform: $(PYTHON) + ./$(PYTHON) -c 'import sys ; from distutils.util import get_platform ; print get_platform()+"-"+sys.version[0:3]' >platform + + +# Build the shared modules +sharedmods: $(PYTHON) + ./$(PYTHON) $(srcdir)/setup.py build + +# Build static library +$(LIBRARY): $(LIBRARY_OBJS) + -rm -f $@ + # avoid long command lines, same as LIBRARY_OBJS + $(AR) cr $@ $(PARSER_OBJS) + $(AR) cr $@ $(OBJECT_OBJS) + $(AR) cr $@ $(PYTHON_OBJS) + $(AR) cr $@ $(MODULE_OBJS) $(SIGNAL_OBJS) + $(AR) cr $@ $(MODOBJS) + $(RANLIB) $@ + +# This rule is only here for DG/UX and BeOS!!! +libpython$(VERSION).so: $(LIBRARY) + case `uname -s | tr -d '/ ' | tr '[A-Z]' '[a-z]'` in \ + *dgux*) \ + test -d dgux || mkdir dgux; \ + (cd dgux;ar x ../$^;ld -G -o ../$@ * ); \ + /bin/rm -rf ./dgux \ + ;; \ + beos) \ + $(srcdir)/BeOS/ar-fake so $(LIBRARY) $@ \ + ;; \ + esac + +# This rule is here for OPENSTEP/Rhapsody/MacOSX +libpython$(VERSION).dylib: $(LIBRARY) + libtool -o $(LDLIBRARY) -dynamic $(OTHER_LIBTOOL_OPT) $(LIBRARY) \ + -framework System @LIBTOOL_CRUFT@ + +# This rule builds the Cygwin Python DLL +libpython$(VERSION).dll.a: $(LIBRARY_OBJS) + dlltool --export-all --output-def $@ $^ + $(LDSHARED) -Wl,--out-implib=$@ -o $(DLLLIBRARY) $^ \ + $(LIBS) $(MODLIBS) $(SYSLIBS) + + +oldsharedmods: $(SHAREDMODS) + + +Makefile Modules/config.c: Makefile.pre \ + $(srcdir)/Modules/config.c.in \ + $(MAKESETUP) \ + Modules/Setup.config \ + Modules/Setup \ + Modules/Setup.local + $(SHELL) $(MAKESETUP) -c $(srcdir)/Modules/config.c.in \ + -s Modules \ + Modules/Setup.config \ + Modules/Setup.local \ + Modules/Setup + @mv config.c Modules + @echo "The Makefile was updated, you may need to re-run make." + + +Modules/Setup: $(srcdir)/Modules/Setup.dist + @if test -f Modules/Setup; then \ + echo "-----------------------------------------------"; \ + echo "Modules/Setup.dist is newer than Modules/Setup;"; \ + echo "check to make sure you have all the updates you"; \ + echo "need in your Modules/Setup file."; \ + echo "-----------------------------------------------"; \ + else cp $(srcdir)/Modules/Setup.dist Modules/Setup; fi + + +Modules/Setup.local: + @echo "# Edit this file for local setup changes" >Modules/Setup.local + + +############################################################################ +# Special rules for object files + +Modules/getbuildinfo.o: $(srcdir)/Modules/getbuildinfo.c buildno + $(CC) -c $(CFLAGS) -DBUILD=`cat buildno` \ + $(srcdir)/Modules/getbuildinfo.c \ + -o Modules/getbuildinfo.o + +Modules/getpath.o: $(srcdir)/Modules/getpath.c Makefile + $(CC) -c $(CFLAGS) -DPYTHONPATH='"$(PYTHONPATH)"' \ + -DPREFIX='"$(prefix)"' \ + -DEXEC_PREFIX='"$(exec_prefix)"' \ + -DVERSION='"$(VERSION)"' \ + -DVPATH='"$(VPATH)"' \ + $(srcdir)/Modules/getpath.c -o $@ + +Modules/ccpython.o: Modules/ccpython.cc + $(CXX) $(CFLAGS) -c $< -o $@ + + +$(GRAMMAR_H) $(GRAMMAR_C): $(PGEN) $(GRAMMAR_INPUT) + $(PGEN) $(GRAMMAR_INPUT) + mv graminit.h $(GRAMMAR_H) + mv graminit.c $(GRAMMAR_C) + +$(PGEN): $(PGENOBJS) + $(CC) $(OPT) $(PGENOBJS) $(LIBS) -o $(PGEN) + +Parser/grammar.o: $(srcdir)/Parser/grammar.c \ + $(srcdir)/Parser/assert.h \ + $(srcdir)/Include/token.h \ + $(srcdir)/Include/grammar.h +Parser/metagrammar.o: $(srcdir)/Parser/metagrammar.c + + +Python/getplatform.o: $(srcdir)/Python/getplatform.c + $(CC) -c $(CFLAGS) -DPLATFORM='"$(MACHDEP)"' \ + -o Python/getplatform.o $(srcdir)/Python/getplatform.c + +Python/importdl.o: $(srcdir)/Python/importdl.c + $(CC) -c $(CFLAGS) -I$(DLINCLDIR) \ + -o Python/importdl.o $(srcdir)/Python/importdl.c + + +Objects/unicodectype.o: $(srcdir)/Objects/unicodectype.c \ + $(srcdir)/Objects/unicodetype_db.h + + +############################################################################ +# Header files + +$(LIBRARY_OBJS) $(MAINOBJ): \ + config.h \ + Include/Python.h \ + Include/patchlevel.h \ + Include/pyport.h \ + Include/pymem.h \ + Include/object.h \ + Include/objimpl.h \ + Include/pydebug.h \ + Include/unicodeobject.h \ + Include/intobject.h \ + Include/longobject.h \ + Include/floatobject.h \ + Include/complexobject.h \ + Include/rangeobject.h \ + Include/stringobject.h \ + Include/bufferobject.h \ + Include/tupleobject.h \ + Include/listobject.h \ + Include/dictobject.h \ + Include/methodobject.h \ + Include/moduleobject.h \ + Include/funcobject.h \ + Include/classobject.h \ + Include/fileobject.h \ + Include/cobject.h \ + Include/traceback.h \ + Include/sliceobject.h \ + Include/codecs.h \ + Include/pyerrors.h \ + Include/pystate.h \ + Include/modsupport.h \ + Include/ceval.h \ + Include/pythonrun.h \ + Include/sysmodule.h \ + Include/intrcheck.h \ + Include/import.h \ + Include/abstract.h \ + Include/pyfpe.h + + +###################################################################### + +# Test the interpreter (twice, once without .pyc files, once with) +TESTOPTS= -l +TESTPROG= $(srcdir)/Lib/test/regrtest.py +TESTPYTHON= ./$(PYTHON) -tt +test: all platform + -rm -f $(srcdir)/Lib/test/*.py[co] + -PYTHONPATH= $(TESTPYTHON) $(TESTPROG) $(TESTOPTS) + PYTHONPATH= $(TESTPYTHON) $(TESTPROG) $(TESTOPTS) + +# Install everything +install: altinstall bininstall maninstall + +# Install almost everything without disturbing previous versions +altinstall: altbininstall libinstall inclinstall libainstall sharedinstall + +# Install shared libraries enabled by Setup +DESTDIRS= $(exec_prefix) $(LIBDIR) $(BINLIBDEST) $(DESTSHARED) + +oldsharedinstall: $(DESTSHARED) $(SHAREDMODS) + @for i in X $(SHAREDMODS); do \ + if test $$i != X; \ + then $(INSTALL_SHARED) $$i $(DESTSHARED)/$$i; \ + fi; \ + done + +$(DESTSHARED): + @for i in $(DESTDIRS); \ + do \ + if test ! -d $$i; then \ + echo "Creating directory $$i"; \ + mkdir $$i; \ + chmod 755 $$i; \ + else true; \ + fi; \ + done + + +# Install the interpreter (by creating a hard link to python$(VERSION)) +bininstall: altbininstall + -if test -f $(BINDIR)/$(PYTHON); \ + then rm -f $(BINDIR)/$(PYTHON); \ + else true; \ + fi + (cd $(BINDIR); $(LN) python$(VERSION)$(EXEEXT) python$(EXEEXT)) + +# Install the interpreter with $(VERSION) affixed +# This goes into $(exec_prefix) +altbininstall: $(PYTHON) + @for i in $(BINDIR); \ + do \ + if test ! -d $$i; then \ + echo "Creating directory $$i"; \ + mkdir $$i; \ + chmod $(DIRMODE) $$i; \ + else true; \ + fi; \ + done + $(INSTALL_PROGRAM) $(PYTHON) $(BINDIR)/python$(VERSION)$(EXEEXT) + if test -f libpython$(VERSION).so; then \ + $(INSTALL_DATA) libpython$(VERSION).so $(LIBDIR); \ + else true; \ + fi + if test -f "$(DLLLIBRARY)"; then \ + $(INSTALL_DATA) $(DLLLIBRARY) $(BINDIR); \ + else true; \ + fi + +# Install the manual page +maninstall: + @for i in $(MANDIR) $(MANDIR)/man1; \ + do \ + if test ! -d $$i; then \ + echo "Creating directory $$i"; \ + mkdir $$i; \ + chmod $(DIRMODE) $$i; \ + else true; \ + fi; \ + done + $(INSTALL_DATA) $(srcdir)/Misc/python.man \ + $(MANDIR)/man1/python.1 + +# Install the library +PLATDIR= plat-$(MACHDEP) +MACHDEPS= $(PLATDIR) +XMLLIBSUBDIRS= xml xml/dom xml/parsers xml/sax +LIBSUBDIRS= lib-old lib-tk site-packages test test/output encodings \ + distutils distutils/command $(XMLLIBSUBDIRS) curses $(MACHDEPS) +libinstall: python $(srcdir)/Lib/$(PLATDIR) + @for i in $(SCRIPTDIR) $(LIBDEST); \ + do \ + if test ! -d $$i; then \ + echo "Creating directory $$i"; \ + mkdir $$i; \ + chmod $(DIRMODE) $$i; \ + else true; \ + fi; \ + done + @for d in $(LIBSUBDIRS); \ + do \ + a=$(srcdir)/Lib/$$d; \ + if test ! -d $$a; then continue; else true; fi; \ + b=$(LIBDEST)/$$d; \ + if test ! -d $$b; then \ + echo "Creating directory $$b"; \ + mkdir $$b; \ + chmod $(DIRMODE) $$b; \ + else true; \ + fi; \ + done + @for i in $(srcdir)/Lib/*.py $(srcdir)/Lib/*.doc; \ + do \ + if test -x $$i; then \ + $(INSTALL_PROGRAM) $$i $(LIBDEST); \ + echo $(INSTALL_PROGRAM) $$i $(LIBDEST); \ + else \ + $(INSTALL_DATA) $$i $(LIBDEST); \ + echo $(INSTALL_DATA) $$i $(LIBDEST); \ + fi; \ + done + @for d in $(LIBSUBDIRS); \ + do \ + a=$(srcdir)/Lib/$$d; \ + if test ! -d $$a; then continue; else true; fi; \ + b=$(LIBDEST)/$$d; \ + for i in $$a/*; \ + do \ + case $$i in \ + *CVS) ;; \ + *.py[co]) ;; \ + *.orig) ;; \ + *~) ;; \ + *) \ + if test -d $$i; then continue; fi; \ + if test -x $$i; then \ + echo $(INSTALL_PROGRAM) $$i $$b; \ + $(INSTALL_PROGRAM) $$i $$b; \ + else \ + echo $(INSTALL_DATA) $$i $$b; \ + $(INSTALL_DATA) $$i $$b; \ + fi;; \ + esac; \ + done; \ + done + $(INSTALL_DATA) $(srcdir)/LICENSE $(LIBDEST)/LICENSE.txt + PYTHONPATH=$(LIBDEST) \ + ./$(PYTHON) -tt $(LIBDEST)/compileall.py $(LIBDEST) + PYTHONPATH=$(LIBDEST) \ + ./$(PYTHON) -O $(LIBDEST)/compileall.py $(LIBDEST) + +# Create the PLATDIR source directory, if one wasn't distributed.. +$(srcdir)/Lib/$(PLATDIR): + mkdir $(srcdir)/Lib/$(PLATDIR) + cp $(srcdir)/Lib/plat-generic/regen $(srcdir)/Lib/$(PLATDIR)/regen + export PATH; PATH="`pwd`:$$PATH"; \ + export PYTHONPATH; PYTHONPATH="`pwd`/Lib"; \ + export EXEEXT; EXEEXT="$(EXEEXT)"; \ + cd $(srcdir)/Lib/$(PLATDIR); ./regen + +# Install the include files +INCLDIRSTOMAKE=$(INCLUDEDIR) $(CONFINCLUDEDIR) $(INCLUDEPY) $(CONFINCLUDEPY) +inclinstall: + @for i in $(INCLDIRSTOMAKE); \ + do \ + if test ! -d $$i; then \ + echo "Creating directory $$i"; \ + mkdir $$i; \ + chmod $(DIRMODE) $$i; \ + else true; \ + fi; \ + done + @for i in $(srcdir)/Include/*.h; \ + do \ + echo $(INSTALL_DATA) $$i $(INCLUDEPY); \ + $(INSTALL_DATA) $$i $(INCLUDEPY); \ + done + $(INSTALL_DATA) config.h $(CONFINCLUDEPY)/config.h + +# Install the library and miscellaneous stuff needed for extending/embedding +# This goes into $(exec_prefix) +LIBPL= $(LIBP)/config +libainstall: all + @for i in $(LIBDIR) $(LIBP) $(LIBPL); \ + do \ + if test ! -d $$i; then \ + echo "Creating directory $$i"; \ + mkdir $$i; \ + chmod $(DIRMODE) $$i; \ + else true; \ + fi; \ + done + @if test -d $(LDLIBRARY); then :; else \ + $(INSTALL_DATA) $(LDLIBRARY) $(LIBPL)/$(LDLIBRARY) ; \ + $(RANLIB) $(LIBPL)/$(LDLIBRARY) ; \ + fi + $(INSTALL_DATA) Modules/config.c $(LIBPL)/config.c + $(INSTALL_DATA) Modules/python.o $(LIBPL)/python.o + $(INSTALL_DATA) $(srcdir)/Modules/config.c.in $(LIBPL)/config.c.in + $(INSTALL_DATA) Makefile $(LIBPL)/Makefile + $(INSTALL_DATA) Modules/Setup $(LIBPL)/Setup + $(INSTALL_DATA) Modules/Setup.local $(LIBPL)/Setup.local + $(INSTALL_DATA) Modules/Setup.config $(LIBPL)/Setup.config + $(INSTALL_PROGRAM) $(srcdir)/Modules/makesetup $(LIBPL)/makesetup + $(INSTALL_PROGRAM) $(srcdir)/install-sh $(LIBPL)/install-sh + $(INSTALL_DATA) $(srcdir)/Misc/Makefile.pre.in $(LIBPL)/Makefile.pre.in + @if [ -s Modules/python.exp -a \ + "`echo $(MACHDEP) | sed 's/^\(...\).*/\1/'`" = "aix" ]; then \ + echo; echo "Installing support files for building shared extension modules on AIX:"; \ + $(INSTALL_DATA) Modules/python.exp \ + $(LIBPL)/python.exp; \ + echo; echo "$(LIBPL)/python.exp"; \ + $(INSTALL_PROGRAM) $(srcdir)/Modules/makexp_aix \ + $(LIBPL)/makexp_aix; \ + echo "$(LIBPL)/makexp_aix"; \ + $(INSTALL_PROGRAM) $(srcdir)/Modules/ld_so_aix \ + $(LIBPL)/ld_so_aix; \ + echo "$(LIBPL)/ld_so_aix"; \ + echo; echo "See Misc/AIX-NOTES for details."; \ + else true; \ + fi + @case "$(MACHDEP)" in beos*) \ + echo; echo "Installing support files for building shared extension modules on BeOS:"; \ + $(INSTALL_DATA) BeOS/README $(LIBPL)/README; \ + echo; echo "$(LIBPL)/README"; \ + $(INSTALL_DATA) BeOS/README.readline-2.2 $(LIBPL)/README.readline-2.2; \ + echo "$(LIBPL)/README.readline-2.2"; \ + $(INSTALL_PROGRAM) BeOS/ar-fake $(LIBPL)/ar-fake; \ + echo "$(LIBPL)/ar-fake"; \ + $(INSTALL_PROGRAM) BeOS/linkmodule $(LIBPL)/linkmodule; \ + echo "$(LIBPL)/linkmodule"; \ + echo; echo "See BeOS/README for details."; \ + ;; \ + esac + +# Install the dynamically loadable modules +# This goes into $(exec_prefix) +sharedinstall: + ./$(PYTHON) $(srcdir)/setup.py install + +# Build the toplevel Makefile +Makefile.pre: Makefile.pre.in config.status + CONFIG_FILES=Makefile.pre CONFIG_HEADERS= $(SHELL) config.status + $(MAKE) -f Makefile.pre Makefile + +# Run the configure script. If config.status already exists, +# call it with the --recheck argument, which reruns configure with the +# same options as it was run last time; otherwise run the configure +# script with options taken from the $(WITH) variable +config.status: $(srcdir)/configure + if test -f config.status; \ + then $(SHELL) config.status --recheck; \ + $(SHELL) config.status; \ + else $(SHELL) $(srcdir)/configure $(WITH); \ + fi + +.PRECIOUS: config.status $(PYTHON) Makefile Makefile.pre + +# Some make's put the object file in the current directory +.c.o: + $(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $< + +# Rerun configure with the same options as it was run last time, +# provided the config.status script exists +recheck: + $(SHELL) config.status --recheck + $(SHELL) config.status + +# Rebuild the configure script from configure.in; also rebuild config.h.in +autoconf: + (cd $(srcdir); autoconf) + (cd $(srcdir); autoheader) + +# Create a tags file for vi +tags:: + cd $(srcdir); \ + ctags -w -t Include/*.h; \ + for i in $(SRCDIRS); do ctags -w -t -a $$i/*.[ch]; \ + done; \ + sort tags -o tags + +# Create a tags file for GNU Emacs +TAGS:: + cd $(srcdir); \ + etags Include/*.h; \ + for i in $(SRCDIRS); do etags -a $$i/*.[ch]; done + +# Sanitation targets -- clean leaves libraries, executables and tags +# files, which clobber removes those as well + +clean: + -rm -f core *~ [@,#]* *.old *.orig *.rej + -rm -rf build + # avoid long command lines, same as LIBRARY_OBJS MAINOBJ PGOBJS + -rm -f $(PARSER_OBJS) + -rm -f $(OBJECT_OBJS) + -rm -f $(PYTHON_OBJS) + -rm -f $(MODULE_OBJS) $(SIGNAL_OBJS) + -rm -f $(MODOBJS) $(MAINOBJ) $(PGOBJS) + +clobber: clean + -rm -f tags TAGS $(PYTHON) $(LIBRARY) $(LDLIBRARY) $(DLLLIBRARY) + -rm -f Makefile.pre config.log config.cache config.h setup.cfg + -rm -f Modules/*.so Modules/*.sl + +# Make things extra clean, before making a distribution: +# remove all generated files, even Makefile[.pre] +distclean: clobber + -$(MAKE) -f $(srcdir)/Makefile.pre.in \ + SUBDIRS="$(SUBDIRSTOO)" clobber + -rm -f config.status config.log config.cache config.h Makefile + -rm -f buildno Modules/Setup Modules/Setup.local Modules/Setup.config + -rm -f Modules/config.c + -for i in $(SUBDIRSTOO); do \ + for f in $$i/*.in; do \ + f=`basename "$$f" .in`; \ + if test "$$f" != "*"; then \ + echo rm -f "$$i/$$f"; \ + rm -f "$$i/$$f"; \ + fi; \ + done; \ + done + +# Check for smelly exported symbols (not starting with Py/_Py) +smelly: all + nm -p $(LIBRARY) | \ + sed -n "/ [TDB] /s/.* //p" | grep -v "^_*Py" | sort -u; \ + +# Find files with funny names +funny: + find $(DISTDIRS) -type d \ + -o -name '*.[chs]' \ + -o -name '*.py' \ + -o -name '*.doc' \ + -o -name '*.sty' \ + -o -name '*.bib' \ + -o -name '*.dat' \ + -o -name '*.el' \ + -o -name '*.fd' \ + -o -name '*.in' \ + -o -name '*.tex' \ + -o -name '*,[vpt]' \ + -o -name 'Setup' \ + -o -name 'Setup.*' \ + -o -name README \ + -o -name Makefile \ + -o -name ChangeLog \ + -o -name Repository \ + -o -name Root \ + -o -name Entries \ + -o -name Tag \ + -o -name tags \ + -o -name TAGS \ + -o -name .cvsignore \ + -o -name MANIFEST \ + -o -print + +# IF YOU PUT ANYTHING HERE IT WILL GO AWAY |