Makefile revision 02e56f3f1bfc8d9977bafb8cb5202f576dcded27
2N/A# The contents of this file are subject to the terms of the 2N/A# Common Development and Distribution License (the "License"). 2N/A# You may not use this file except in compliance with the License. 2N/A# See the License for the specific language governing permissions 2N/A# and limitations under the License. 2N/A# When distributing Covered Code, include this CDDL HEADER in each 2N/A# If applicable, add the following below this CDDL HEADER, with the 2N/A# fields enclosed by brackets "[]" replaced with your own identifying 2N/A# information: Portions Copyright [yyyy] [name of copyright owner] 2N/A# Copyright 2005 Sun Microsystems, Inc. All rights reserved. 2N/A# Use is subject to license terms. 2N/A# ident "%Z%%M% %I% %E% SMI" 2N/A# The perl5 installation for Solaris differs from that generated by the 2N/A# Perl Configure procedure. The configuration appropriate for the current 2N/A# build is automatically generated from pre-existing configuration files 2N/A# for the build platform. 2N/A# DynaLoader is a special extension as it has to be built statically. 2N/A# Uuencoded files that need to have SCCS keyword expansion prevented, see below. 2N/A# Because autosplit generates a lot of files, we create a dummy timestamp file 2N/A# so that dependency checking can be performed. 2N/A# Add in the perl-specific flags (including largefile flags). 2N/A# Add in the libraries perl needs to be linked against. 2N/A# Compiler replacement rules 2N/A# Some of the files in the perl distribution are uuencoded, or contain uuencoded 2N/A# data. Some of the sequences of uuencoded data look like SCCS keywords, i.e. 2N/A# "%<letter>%", so it is necessary to prevent the keywords from being expanded. 2N/A# The SCCS 'y' flag can be added to the SCCS files to prevent keyword expansion 2N/A# when the file is retrieved. However due to bugs in SCCS and wx we can't 2N/A# always be sure that these flags are propagated correctly. 2N/A# which uses the correct library build environment. 2N/A# Build miniperl, the bootstrap perl executable, and check it executes OK. 2N/A# opmini.o is a version of op.o compiled with -DPERL_EXTERNAL_GLOB. Perl has 2N/A# an internal implementation of glob, but it isn't available at this point. 2N/A# Prepare for building perl modules by: 2N/A# * Building miniperl. 2N/A# * Autosplitting any ./lib modules that require it. 2N/A# * Creating a fake cflags file. ExtUtils::MM_Unix (used to build extensions) 2N/A# checks to see if there is a non-zero sized file called 'cflags' in this 2N/A# directory, so we fool it by creating one. 2N/A# Note: cflags needs to be non-zero sized, so $(TOUCH) won't do. 2N/A# Because autosplit generates a lot of files, we create a dummy timestamp file 2N/A# Make DynaLoader. DynaLoader is statically linked into the perl executable 2N/A# because it is used to load in all the other dynamically loaded modules. 2N/A# Note: VERSION is used by ON as a environment variable and by perl module 2N/A# makefiles as a make macro, so we need to unset it before building any modules. 2N/A# Create the perl executable. 2N/A# Build all the extensions. The rules for this are in the generated 2N/A# Build utilities and pod pages. 2N/A# Install targets. The bin, lib and pod symlinks are created here. The man 2N/A# link is created by the SUNWpl5m package. In order to prevent a symlink cycle 2N/A# we need to remove libperl.so before we start, so it will always be reinstalled 2N/A# on each 'make install'. We also overwrite the Config.pm we used to build our 2N/A# modules with one sanitized of the /ws/on*-tools dependency. As a result, 2N/A# Config.pm will also be overwritten on each 'make install'. Note also that 2N/A# perl, pstruct and psed are all hard links, so they too are reinstalled on each 2N/A# Perl test suite target. 2N/A# Note: the perl test suite breaks under parallel make. Bah. 2N/A# @ (PERL_MM_ENV); $(PERL_LD_ENV);