Makefile revision 3795
278N/A#
278N/A# CDDL HEADER START
278N/A#
278N/A# The contents of this file are subject to the terms of the
278N/A# Common Development and Distribution License (the "License").
278N/A# You may not use this file except in compliance with the License.
278N/A#
278N/A# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
278N/A# or http://www.opensolaris.org/os/licensing.
278N/A# See the License for the specific language governing permissions
278N/A# and limitations under the License.
278N/A#
278N/A# When distributing Covered Code, include this CDDL HEADER in each
278N/A# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
278N/A# If applicable, add the following below this CDDL HEADER, with the
278N/A# fields enclosed by brackets "[]" replaced with your own identifying
278N/A# information: Portions Copyright [yyyy] [name of copyright owner]
278N/A#
278N/A# CDDL HEADER END
278N/A#
3996N/A# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
278N/A
278N/A#
278N/Ainclude ../../../make-rules/shared-macros.mk
1273N/A
278N/APATH=/usr/bin:/usr/gnu/bin:/usr/sbin
618N/A
1273N/ACOMPONENT_NAME= Python
1273N/ACOMPONENT_VERSION= 2.7.9
278N/ACOMPONENT_PROJECT_URL= http://python.org/
844N/ACOMPONENT_SRC= $(COMPONENT_NAME)-$(COMPONENT_VERSION)
844N/ACOMPONENT_ARCHIVE= $(COMPONENT_SRC).tar.xz
278N/ACOMPONENT_ARCHIVE_HASH= \
1273N/A sha256:90d27e14ea7e03570026850e2e50ba71ad20b7eb31035aada1cf3def8f8d4916
278N/ACOMPONENT_ARCHIVE_URL= $(COMPONENT_PROJECT_URL)ftp/python/$(COMPONENT_VERSION)/$(COMPONENT_ARCHIVE)
3661N/ACOMPONENT_SIG_URL= $(COMPONENT_ARCHIVE_URL).asc
3661N/ACOMPONENT_BUGDB= utility/python
3996N/A
3996N/ATPNO= 20750
3996N/A
278N/Ainclude $(WS_TOP)/make-rules/prep.mk
278N/Ainclude $(WS_TOP)/make-rules/configure.mk
278N/Ainclude $(WS_TOP)/make-rules/ips.mk
278N/Ainclude $(WS_TOP)/make-rules/lint-libraries.mk
278N/A
278N/A# Need to preserve timestamp for Grammar files. If the pickle files are older,
278N/A# Python will try to rebuild them.
278N/APKGSEND_PUBLISH_OPTIONS += -T \*Grammar\*.txt
278N/APKGSEND_PUBLISH_OPTIONS += -T \*Grammar\*.pickle
278N/A
278N/A# We patch auto* files, so regenerate headers and configure
278N/ACOMPONENT_PREP_ACTION = \
278N/A (cd $(@D) ; autoheader ; autoconf)
278N/A
278N/A# we don't want to leak $(CC_BITS) into BASECFLAGS as it causes problems with
278N/A# python-config
278N/ACC += $(CFLAGS)
278N/A
278N/AC99MODE=
278N/ACPPFLAGS += -IPython
278N/A
278N/A# to find the ncurses headers
278N/ACPPFLAGS += -I/usr/include/ncurses
278N/A# enable large files how they did in JDS
3996N/ACPPFLAGS += -D_LARGEFILE64_SOURCE
# libffi for _ctypes
CPPFLAGS += $(shell pkg-config --cflags-only-I libffi)
# because python links with $(CC) ... $(LDFLAGS) ...
LDFLAGS = $(CC_BITS) $(CC_PIC)
# build pic
CFLAGS += $(CC_PIC)
# The python build is profile-guided for studio; to see the benefits of that,
# Python must be compiled with -xO5 and a different build target must be used.
# Use of xprofile requires that the same options be used during compilation and
# linking. The targets chosen are based on Solaris 11 minimum supported system
# requirements.
COMPONENT_BUILD_TARGETS = profile-opt
XPROFILE_DIR = $(BUILD_DIR_$(BITS))/.profile
PYFLAGS.i386 = -xtarget=opteron -xarch=sse2 -xcache=generic
PYFLAGS.sparc =
CFLAGS += -xO5 $(PYFLAGS.$(MACH))
LDFLAGS += -xO5 $(PYFLAGS.$(MACH))
# add /usr/gnu/lib to the library search/run path
LDFLAGS.32 = -R/usr/gnu/lib -L/usr/gnu/lib
LDFLAGS.64 = -R/usr/gnu/lib/$(MACH64) -L/usr/gnu/lib/$(MACH64)
LDFLAGS += $(LDFLAGS.$(BITS))
# Python puts its header files in a special place.
LINT_FLAGS += -I$(SOURCE_DIR)/Include
# PYTHONPATH in the environment can be harmful, but setting it to empty via
# _INSTALL_ENV causes problems too, so just ignore the entire environment.
# Because of this, we need to specify PATH in multiple places below.
ENV += -i
CONFIGURE_ENV += PATH="$(PATH)"
CONFIGURE_OPTIONS += --infodir=$(CONFIGURE_INFODIR)
CONFIGURE_OPTIONS += --enable-shared
CONFIGURE_OPTIONS += --with-system-expat
CONFIGURE_OPTIONS += --with-system-ffi
CONFIGURE_OPTIONS += --without-gcc
CONFIGURE_OPTIONS += --enable-ipv6
CONFIGURE_OPTIONS += CPPFLAGS="$(CPPFLAGS)"
CONFIGURE_OPTIONS += LDFLAGS="$(LDFLAGS)"
CONFIGURE_OPTIONS += CFLAGS="$(CFLAGS)"
CONFIGURE_OPTIONS += DFLAGS="-$(BITS)"
CONFIGURE_OPTIONS += XPROFILE_DIR="$(XPROFILE_DIR)"
COMPONENT_BUILD_ENV += PATH="$(PATH)"
COMPONENT_BUILD_ENV += DFLAGS="-$(BITS)"
COMPONENT_BUILD_ENV += XPROFILE_DIR="$(XPROFILE_DIR)"
# 64 bit shared objects need to go in a 64-bit directory
COMPONENT_INSTALL_ARGS.64 += DESTSHARED=$(CONFIGURE_PREFIX)/lib/python2.7/lib-dynload
# Simplify the definitions of CC, CXX, CFLAGS and LDFLAGS so they hard-code
# neither paths from our build systems nor Studio-specific options.
COMPONENT_PRE_INSTALL_ACTION= \
(cd $(@D) ; $(GSED) -i -e 's/^CC=.*/CC=\t\tcc/' \
-e 's/^CXX=.*/CXX=\t\tCC/' \
-e 's/^CFLAGS=.*/CFLAGS=\t\t\$$\(BASECFLAGS) \$$\(OPT) \$$\(EXTRA_CFLAGS)/' \
-e 's|^LDFLAGS=.*|LDFLAGS=|' \
Makefile)
# Because we stripped the Makefile above, we need to pass several things in the
# environment, and use -e to tell gmake to pay attention to the environment.
COMPONENT_INSTALL_ENV += CC="$(CC)"
COMPONENT_INSTALL_ENV += CXX="$(CXX)"
COMPONENT_INSTALL_ENV += CFLAGS="$(CFLAGS)"
COMPONENT_INSTALL_ENV += LDFLAGS="$(LDFLAGS)"
COMPONENT_INSTALL_ENV += PATH="$(PATH)"
COMPONENT_INSTALL_ARGS += -e
# 1. Setup pyconfig.h file to support 32 & 64 bit.
# 2. If the /usr/lib/python2.7/lib2to3/*.pickle files are older than the
# related *.txt files in the same directory, it will rebuild them any time
# you try to build a Python module. So here we also touch the pickle files
# to avoid this.
# 3. Strip build machine paths from _sysconfigdata.py & config/Makefile.
# Note that although the 64-bit version is not used (and thus commented
# out in the manifest), we still need to specify the 32-/64-bit paths,
# otherwise the 64-bit build will fail to find the 32-bit path.
CONFIG_MAKEFILE.32= lib/python2.7/config/Makefile
CONFIG_MAKEFILE.64= lib/$(MACH64)/python2.7/config/Makefile
CONFIG_MAKEFILE= $(CONFIG_MAKEFILE.$(BITS))
COMPONENT_POST_INSTALL_ACTION= \
(cd $(PROTOUSRDIR) ; \
$(MV) include/python2.7/pyconfig.h include/python2.7/pyconfig-$(BITS).h ; \
$(TOUCH) lib/python2.7/lib2to3/*.pickle ; \
$(GSED) -i -e 's|$(SOURCE_DIR)|.|g' -e 's|$(COMPONENT_DIR)|..|g' \
-e 's|$(SPRO_VROOT)/bin/||g' lib/python2.7/_sysconfigdata.py \
$(CONFIG_MAKEFILE))
ASLR_MODE = $(ASLR_ENABLE)
# common targets
$(INSTALL_32): $(INSTALL_64)
build: $(BUILD_32_and_64)
install: $(INSTALL_32_and_64)
# Using "-uall,-network" ensures all tests are run except the network tests.
# The network tests contain many expected failures when run behind a firewall.
# The "-v" ensures verbose mode. You can set TESTOPTS_PYTHON_TEST to a
# particular test if you want to run just one test. For example, run gmake with
# "-k" so it continues and does both 32-bit and 64-bit tests, even if there is a
# failure, like this:
# $ TESTOPTS_PYTHON_TEST=test_sys gmake -k test
# Note that when a test succeeds, the builds/*/.tested file gets created. You
# may need to remove these files, or run "gmake clobber" or "gmake clean"
# between tests.
#
COMPONENT_TEST_ENV = EXTRATESTOPTS="-v -uall,-network $(TESTOPTS_PYTHON_TEST)"
# The distutils tests need $CC in $PATH.
COMPONENT_TEST_ENV += PATH="$(SPRO_VROOT)/bin:$(PATH)"
COMPONENT_TEST_TARGETS = test
test: $(TEST_32_and_64)
BUILD_PKG_DEPENDENCIES = $(BUILD_TOOLS)
include $(WS_TOP)/make-rules/depend.mk