4910N/A# The contents of this file are subject to the terms of the 4910N/A# Common Development and Distribution License (the "License"). 4910N/A# You may not use this file except in compliance with the License. 4910N/A# See the License for the specific language governing permissions 4910N/A# and limitations under the License. 4910N/A# When distributing Covered Code, include this CDDL HEADER in each 4910N/A# If applicable, add the following below this CDDL HEADER, with the 4910N/A# fields enclosed by brackets "[]" replaced with your own identifying 4910N/A# information: Portions Copyright [yyyy] [name of copyright owner] 5466N/A# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. 4910N/A# Need to preserve timestamp for Grammar files. If the pickle files are older, 4910N/A# Python will try to rebuild them. 4910N/A# We patch auto* files, so regenerate headers and configure 4910N/A# The DTrace patch needs this file to be mode 0755. 4910N/A# we don't want to leak $(CC_BITS) into BASECFLAGS as it causes problems with 4910N/A# to find the ncurses headers 4910N/A# enable large files how they did in JDS 4910N/A# because python links with $(CC) ... $(LDFLAGS) ... 5934N/A# Use the Studio VIS SDK in order to explicitly generate nonfaulting loads 5934N/A# that allow Python to work with ADI-aware memory allocators. 4910N/A# 16-byte memory alignment + interpretation of non-alignment prevents SIGBUS. 4910N/A# The python build is profile-guided for studio; to see the benefits of that, 4910N/A# Python must be compiled with -xO5 and a different build target must be used. 4910N/A# Use of xprofile requires that the same options be used during compilation and 4910N/A# linking. The targets chosen are based on Solaris 11 minimum supported system 4910N/A# Python puts its header files in a special place. 4910N/A# PYTHONPATH in the environment can be harmful, but setting it to empty via 4910N/A# _INSTALL_ENV causes problems too, so just ignore the entire environment. 4910N/A# Because of this, we need to specify PATH in multiple places below. 4910N/A# Some tests have non-ASCII characters encoded for international domain names; 4910N/A# the publish step will fail in 'pkgdepend generate' without this: 4910N/A# 64 bit shared objects need to go in a 64-bit directory 4910N/A# Simplify the definitions of CC, CXX, CFLAGS and LDFLAGS so they hard-code 4910N/A# neither paths from our build systems nor Studio-specific options. 4910N/A $(GSED) -i -e 's/^CC=.*/CC=\t\tcc/' -e 's/^CXX=.*/CXX=\t\tCC/' \ 4910N/A -e 's/^CFLAGS=.*/CFLAGS=\t\t\$$\(BASECFLAGS) \$$\(OPT) \$$\(EXTRA_CFLAGS)/' \ 4910N/A# Because we stripped the Makefile above, we need to pass several things in the 4910N/A# environment, and use -e to tell gmake to pay attention to the environment. 4910N/A# Note that once Python 3.5 has been integrated and propagated to build 4910N/A# machines, then the LD_LIBRARY_PATH setting and PROTO_DIR prefix below 4910N/A $(GSED) -i -e 's|$(SOURCE_DIR)|.|g' -e 's|$(COMPONENT_DIR)|..|g' \ 4910N/A# Using "-uall,-network" ensures all tests are run except the network tests. 4910N/A# The network tests contain many expected failures when run behind a firewall. 4910N/A# The "-v" ensures verbose mode. You can set TESTOPTS_PYTHON_TEST to a 4910N/A# particular test if you want to run just one test. For example, 4910N/A# $ TESTOPTS_PYTHON_TEST=test_sys gmake -k test 4910N/A# Note that when a test succeeds, the builds/*/.tested file gets created. You 4910N/A# may need to remove these files, or run "gmake clobber" or "gmake clean" 4910N/A# The distutils tests need $CC in $PATH. 4910N/A# Prevent the tests from getting stuck waiting for input. 4910N/A# Some different values for system testing. 4910N/A# The test output contains details from each test, in whatever order they 4910N/A# complete. The default _TRANSFORMER is not powerful enough to deal with 4910N/A# this; we need heavier artillery. Extract just the sections that start 4910N/A# with "tests OK." and end with "Re-running failed tests..." for comparison.