#
# CDDL HEADER START
#
# The contents of this file are subject to the terms of the
# Common Development and Distribution License (the "License").
# You may not use this file except in compliance with the License.
#
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
# See the License for the specific language governing permissions
# and limitations under the License.
#
# When distributing Covered Code, include this CDDL HEADER in each
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
# If applicable, add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your own identifying
# information: Portions Copyright [yyyy] [name of copyright owner]
#
# CDDL HEADER END
#
#
#
# Need to preserve timestamp for Grammar files. If the pickle files are older,
# Python will try to rebuild them.
# We patch auto* files, so regenerate headers and configure
# The DTrace patch needs this file to be mode 0755.
# we don't want to leak $(CC_BITS) into BASECFLAGS as it causes problems with
# python-config
# to find the ncurses headers
# enable large files how they did in JDS
# libffi for _ctypes
# because python links with $(CC) ... $(LDFLAGS) ...
# build pic
# for DWARF
# Use the Studio VIS SDK in order to explicitly generate nonfaulting loads
# that allow Python to work with ADI-aware memory allocators.
# 16-byte memory alignment + interpretation of non-alignment prevents SIGBUS.
# 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.
# Python puts its header files in a special place.
# 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
# Some tests have non-ASCII characters encoded for international domain names;
# the publish step will fail in 'pkgdepend generate' without this:
# 64 bit shared objects need to go in a 64-bit directory
# Simplify the definitions of CC, CXX, CFLAGS and LDFLAGS so they hard-code
# neither paths from our build systems nor Studio-specific options.
(cd $(@D) ; \
-e 's/^CFLAGS=.*/CFLAGS=\t\t\$$\(BASECFLAGS) \$$\(OPT) \$$\(EXTRA_CFLAGS)/' \
# 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_ARGS += -e
# Strip build machine paths from _sysconfigdata.py & config/Makefile,
# then (re)compile _sysconfigdata.py since we just updated it.
# common targets
install: $(INSTALL_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,
# $ 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.
#
# The distutils tests need $CC in $PATH.
# Prevent the tests from getting stuck waiting for input.
# Some different values for system testing.
# The test output contains details from each test, in whatever order they
# complete. The default _TRANSFORMER is not powerful enough to deal with
# this; we need heavier artillery. Extract just the sections that start
# with "tests OK." and end with "Re-running failed tests..." for comparison.
COMPONENT_TEST_TRANSFORMS = "'/tests OK./ {results = 1}; /Re-running failed tests in verbose mode/ {results = 0} {if (results) print $0 } '"
test: $(TEST_64)
system-test: $(SYSTEM_TEST_64)