diff options
author | Hye-Shik Chang <perky@FreeBSD.org> | 2006-10-09 14:29:18 +0000 |
---|---|---|
committer | Hye-Shik Chang <perky@FreeBSD.org> | 2006-10-09 14:29:18 +0000 |
commit | 1d18bb4fff9ca7e0fca8452b1874fe1f58ffca6f (patch) | |
tree | 147f92d454787d912bee658515932bf0eeae4d6c /lang/python/Makefile | |
parent | a109e33441e4540e21473b7b27b9c549e09d3c0e (diff) | |
download | ports-1d18bb4fff9ca7e0fca8452b1874fe1f58ffca6f.tar.gz ports-1d18bb4fff9ca7e0fca8452b1874fe1f58ffca6f.zip |
- Update the main python version to 2.5.
- Now, lang/python is just a meta-port which depends on lang/python25.
- And all versions of Python ports have short version identifier in its
package name; python25-2.5, python24-2.4.3 and etc.
- Also you must upgrade all python modules after lang/python updated,
cd /usr/ports/lang/python && make upgrade-site-packages
- Give maintainership of Python ports to the new python@ group which
includes me, alexbl@ and others.
Notes
Notes:
svn path=/head/; revision=175093
Diffstat (limited to 'lang/python/Makefile')
-rw-r--r-- | lang/python/Makefile | 205 |
1 files changed, 12 insertions, 193 deletions
diff --git a/lang/python/Makefile b/lang/python/Makefile index f3598853adf7..6983b34c3dc2 100644 --- a/lang/python/Makefile +++ b/lang/python/Makefile @@ -6,213 +6,32 @@ # PORTNAME= python -PORTVERSION= 2.4.3 -PORTREVISION= 1 +PORTVERSION= ${PYTHON_PORTVERSION} CATEGORIES= lang python ipv6 -MASTER_SITES= ${PYTHON_MASTER_SITES} -MASTER_SITE_SUBDIR= ${PYTHON_MASTER_SITE_SUBDIR} -DISTFILES= ${PYTHON_DISTFILE} +MASTER_SITES= # empty +DISTFILES= # empty +EXTRACT_ONLY= # empty -MAINTAINER= perky@FreeBSD.org -COMMENT?= An interpreted object-oriented programming language - -CONFLICTS= python-mode.el-1.* -DIST_SUBDIR= python -WRKSRC= ${PYTHON_WRKSRC} -GNU_CONFIGURE= yes -CONFIGURE_TARGET= --build=${MACHINE_ARCH}-portbld-freebsd${OSREL} -CONFIGURE_ENV= OPT="${CFLAGS}" -MAKE_ENV= VPATH="${WRKSRC}" -INSTALLS_SHLIB= yes -INSTALL_TARGET= install -MAN1= python.1 +MAINTAINER= python@FreeBSD.org +COMMENT= The "meta-port" for the stable version of Python interpreter USE_PYTHON= yes -PYTHON_VERSION= python2.4 -PYTHON_NO_DEPENDS= yes - -SHARED_WRKSRC= ${WRKSRC}/build.shared -PLIST= ${WRKDIR}/pkg-plist -PLIST_SUB= PYVER=${PYTHON_VERSION:S/python//} -DEMODIR= ${PREFIX}/share/examples/${PYTHON_VERSION} -TOOLSDIR= ${PREFIX}/share/${PYTHON_VERSION} - -.if !exists(/usr/bin/ypcat) # the world with NO_NIS -PLISTCAT= ${GREP} -v 'nis.so$$' ${PKGDIR}/pkg-plist -.else -PLISTCAT= ${CAT} ${PKGDIR}/pkg-plist -.endif - -OPTIONS= THREADS "Enable thread support" on \ - HUGE_STACK_SIZE "Use a larger thread stack" off \ - UCS4 "Use UCS4 for unicode support" on \ - PYMALLOC "Use python's internal malloc" on \ - IPV6 "Enable IPv6 support" on \ - FPECTL "Enable floating point exception handling" off - -.include <bsd.port.pre.mk> - -# workaround for a bug in base curses.h. -CFLAGS+= -D__wchar_t=wchar_t - -.if !defined(WITHOUT_THREADS) -CONFIGURE_ARGS+= --with-threads -CFLAGS+= ${PTHREAD_CFLAGS} -.if defined(WITHOUT_HUGE_STACK_SIZE) -CFLAGS+= -DTHREAD_STACK_SIZE=0x20000 -.else -CFLAGS+= -DTHREAD_STACK_SIZE=0x100000 -.endif # defined(WITHOUT_HUGE_STACK_SIZE) -CONFIGURE_ENV+= LDFLAGS="${PTHREAD_LIBS} ${LDFLAGS}" -.else -CONFIGURE_ARGS+= --without-threads -.if defined(LDFLAGS) -CONFIGURE_ENV+= LDFLAGS="${LDFLAGS}" -.endif # defined(LDFLAGS) -.endif # !defined(WITHOUT_THREADS) - -.if !defined(WITHOUT_UCS4) && !defined(WITH_UCS2) -CONFIGURE_ARGS+= --enable-unicode=ucs4 -.endif - -.if defined(WITHOUT_PYMALLOC) -CONFIGURE_ARGS+= --without-pymalloc -.endif - -.if ${ARCH} == i386 -PLIST_SUB+= X86_ONLY="" -.else -PLIST_SUB+= X86_ONLY="@comment " -.endif -.if ${ARCH} == amd64 || ${ARCH} == ia64 || ${ARCH} == sparc64 || ${ARCH} == alpha -PLIST_SUB+= 32BIT_ONLY="@comment " -.else -PLIST_SUB+= 32BIT_ONLY="" -.endif -.if ${ARCH} == sparc64 -CFLAGS+= -DPYTHON_DEFAULT_RECURSION_LIMIT=900 -.endif - -.if !defined(WITHOUT_IPV6) && ${OSVERSION} >= 400014 -CONFIGURE_ARGS+= --enable-ipv6 -.else -CONFIGURE_ARGS+= --disable-ipv6 -.endif - -.if defined(WITH_FPECTL) -CONFIGURE_ARGS+= --with-fpectl -.endif - -.if ${OSVERSION} >= 700000 -PLATFORMS=plat-freebsd4 plat-freebsd5 plat-freebsd6 -.elif ${OSVERSION} >= 600000 -PLATFORMS=plat-freebsd4 plat-freebsd5 plat-freebsd7 -.elif ${OSVERSION} >= 500000 -PLATFORMS=plat-freebsd4 plat-freebsd6 plat-freebsd7 -.else -PLATFORMS=plat-freebsd5 plat-freebsd6 plat-freebsd7 -.endif - -post-extract: - ${SED} -e '1s,^.*$$,#!${PREFIX}/bin/${PYTHON_VERSION},' \ - ${WRKSRC}/Tools/scripts/pydoc > ${WRKDIR}/pydoc2.4 - ${SED} -e '1s,^.*$$,#!${PREFIX}/bin/${PYTHON_VERSION},' \ - ${WRKSRC}/Tools/scripts/idle > ${WRKDIR}/idle2.4 - ${SED} -e '1s,^.*$$,#!${PREFIX}/bin/${PYTHON_VERSION},' \ - ${WRKSRC}/Lib/smtpd.py > ${WRKDIR}/smtpd2.4.py - -pre-patch: - ${REINPLACE_CMD} -e \ - 's,/usr/doc/python-docs-,${PREFIX}/share/doc/python,g' \ - ${WRKSRC}/Lib/pydoc.py - ${REINPLACE_CMD} -e \ - 's|^\( *prefixes = .*\)\]$$|\1, "${X11BASE}"]|g' \ - ${WRKSRC}/Lib/site.py -.if defined(WITH_FPECTL) && ${ARCH} == i386 - ${ECHO} "fpectl fpectlmodule.c" >> ${WRKSRC}/Modules/Setup.dist -.endif - -post-configure: - @# prepare a subdir for shared build -.for subdir in Modules Parser Python Objects - ${MKDIR} ${SHARED_WRKSRC}/${subdir} -.endfor - ${SED} -e 's,^\(LDLIBRARY=\).*$$,\1libpython$$(VERSION).so,' \ - -e 's,^\(BLDLIBRARY=\).*$$,\1-L. -lpython$$(VERSION),' \ - -e 's,^\(CFLAGSFORSHARED=\).*$$,\1$$(CCSHARED),' \ - -e 's,^\(Makefile Modules/config.c:.*\)Makefile.pre,\1,' \ - -e 's,^\(.(BUILDPYTHON):.*\).(LIBRARY),\1,' \ - ${WRKSRC}/Makefile > ${SHARED_WRKSRC}/Makefile - ${LN} -sf ${WRKSRC}/pyconfig.h ${WRKSRC}/Include ${WRKSRC}/Grammar \ - ${SHARED_WRKSRC}/ - ${LN} -sf ${WRKSRC}/Python/getplatform.c ${WRKSRC}/Python/importdl.c \ - ${WRKSRC}/Python/importdl.h \ - ${SHARED_WRKSRC}/Python/ - ${LN} -sf ${WRKSRC}/Modules/makesetup ${WRKSRC}/Modules/Setup* \ - ${WRKSRC}/Modules/*.c ${WRKSRC}/Modules/*.h \ - ${SHARED_WRKSRC}/Modules/ - -post-build: - cd ${SHARED_WRKSRC}; \ - ${SETENV} ${MAKE_ENV} ${MAKE} lib${PYTHON_VERSION}.so python; \ - ${LN} -f lib${PYTHON_VERSION}.so lib${PYTHON_VERSION}.so.1; \ - ${LN} -f python ${PYTHON_VERSION:S/thon/thon-shared/} - -pre-su-install: -.for platform in ${PLATFORMS} - ${MKDIR} ${PYTHONPREFIX_LIBDIR}/${platform} -.for file in IN.py regen - ${INSTALL_DATA} ${WRKSRC}/Lib/${platform}/${file} \ - ${PYTHONPREFIX_LIBDIR}/${platform}/ -.endfor -.endfor - -pre-install: - ${PLISTCAT} | ${AWK} '{ print $$0; } \ - /LIBDIR.*\.py$$/ && !/\/bad/ { print $$0 "o"; print $$0 "c"; }' \ - > ${PLIST} - -post-install: - @# shared version of executable and library - ${INSTALL_PROGRAM} ${SHARED_WRKSRC}/lib${PYTHON_VERSION}.so.1 \ - ${PREFIX}/lib - cd ${PREFIX}/lib; ${LN} -sf lib${PYTHON_VERSION}.so.1 \ - lib${PYTHON_VERSION}.so - ${LN} -sf ${PREFIX}/lib/lib${PYTHON_VERSION}.so ${PYTHONPREFIX_LIBDIR}/config - ${INSTALL_PROGRAM} \ - ${SHARED_WRKSRC}/${PYTHON_VERSION:S/thon/thon-shared/} \ - ${PREFIX}/bin - cd ${PREFIX}/bin; \ - ${LN} -f ${PYTHON_VERSION:S/thon/thon-shared/} python-shared - - @# additional files installing by ports - ${INSTALL_DATA} ${WRKSRC}/Misc/python-mode.el \ - ${PREFIX}/share/emacs/site-lisp - ${INSTALL_SCRIPT} ${WRKDIR}/pydoc2.4 ${WRKDIR}/idle2.4 \ - ${WRKDIR}/smtpd2.4.py ${PREFIX}/bin - -.if !defined(NOPORTDOCS) - @${MKDIR} ${TOOLSDIR} - @cd ${WRKSRC}; tar -c --exclude='*CVS*' -f - Tools | \ - (cd ${TOOLSDIR}; tar xf -) - @${MKDIR} ${DEMODIR} - @cd ${WRKSRC}/Demo; tar -c --exclude='*CVS*' -f - * | \ - (cd ${DEMODIR}; tar xf -) -.endif +NO_BUILD= yes - @${CAT} ${PKGMESSAGE} +do-install: # empty +# Major upgrade support PORTUPGRADE?= ${LOCALBASE}/sbin/portupgrade PKG_WHICH?= ${LOCALBASE}/sbin/pkg_which upgrade-site-packages: @if [ -x ${PORTUPGRADE} ]; then \ - for ver in 2.1 2.2 2.3; do \ + for ver in 2.1 2.2 2.3 2.4; do \ if [ -d ${PREFIX}/lib/python$$ver ]; then \ UPD=`${FIND} ${PREFIX}/lib/python$$ver \ -type f -print0 | \ ${XARGS} -0 ${PKG_WHICH} | \ ${GREP} -Fv '?' | \ - ${GREP} -v '^python-2' | \ + ${EGREP} -v '^python2?[0-4]?-2' | \ ${SORT} -u`; \ if [ "$$UPD" ]; then \ ${PORTUPGRADE} -f $$UPD; \ @@ -224,4 +43,4 @@ upgrade-site-packages: ${FALSE}; \ fi -.include <bsd.port.post.mk> +.include <bsd.port.mk> |