Makefile.inc revision 957
0N/A# -*- Makefile -*- rules commonly shared among X consolidation open source dirs
0N/A#
935N/A# Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved.
0N/A#
0N/A# Permission is hereby granted, free of charge, to any person obtaining a
919N/A# copy of this software and associated documentation files (the "Software"),
919N/A# to deal in the Software without restriction, including without limitation
919N/A# the rights to use, copy, modify, merge, publish, distribute, sublicense,
919N/A# and/or sell copies of the Software, and to permit persons to whom the
919N/A# Software is furnished to do so, subject to the following conditions:
919N/A#
919N/A# The above copyright notice and this permission notice (including the next
919N/A# paragraph) shall be included in all copies or substantial portions of the
919N/A# Software.
919N/A#
919N/A# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
919N/A# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
919N/A# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
919N/A# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
919N/A# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
919N/A# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
919N/A# DEALINGS IN THE SOFTWARE.
0N/A#
0N/A#
0N/A
493N/A### Default rules
156N/A
493N/A# Which compiler to use to build module
493N/AMODTYPE_COMPILER_DEFAULT = $(MODTYPE_COMPILER_SET:yes=$(POUND_SIGN))
493N/A$(MODTYPE_COMPILER_DEFAULT) MODTYPE_COMPILER = $(DEFAULT_COMPILER)
493N/AMODULE_COMPILER_DEFAULT = $(MODULE_COMPILER_SET:yes=$(POUND_SIGN))
493N/A$(MODULE_COMPILER_DEFAULT) MODULE_COMPILER = $(MODTYPE_COMPILER)
0N/A
493N/A# Which make to use to build module
493N/AMODTYPE_MAKE_DEFAULT = $(MODTYPE_MAKE_SET:yes=$(POUND_SIGN))
493N/A$(MODTYPE_MAKE_DEFAULT) MODTYPE_MAKE = $(MAKE)
493N/AMODULE_MAKE_DEFAULT = $(MODULE_MAKE_SET:yes=$(POUND_SIGN))
493N/A$(MODULE_MAKE_DEFAULT) MODULE_MAKE = $(MODTYPE_MAKE)
0N/A
493N/A# Where to install files
493N/AMODTYPE_PREFIX_DEFAULT = $(MODTYPE_PREFIX_SET:yes=$(POUND_SIGN))
851N/A$(MODTYPE_PREFIX_DEFAULT) MODTYPE_PREFIX=$(X11_DIR)
493N/AMODULE_PREFIX_DEFAULT = $(MODULE_PREFIX_SET:yes=$(POUND_SIGN))
493N/A$(MODULE_PREFIX_DEFAULT) MODULE_PREFIX=$(MODTYPE_PREFIX)
0N/A
851N/A# Where to install pkgconfig files
851N/AMODTYPE_PKGCONFIG_DIR_DEFAULT = $(MODTYPE_PKGCONFIG_DIR_SET:yes=$(POUND_SIGN))
851N/A$(MODTYPE_PKGCONFIG_DIR_DEFAULT) MODTYPE_PKGCONFIG_DIR=$(PKGCONFIG_DIR)
851N/AMODULE_PKGCONFIG_DIR_DEFAULT = $(MODULE_PKGCONFIG_DIR_SET:yes=$(POUND_SIGN))
851N/A$(MODULE_PKGCONFIG_DIR_DEFAULT) MODULE_PKGCONFIG_DIR=$(MODTYPE_PKGCONFIG_DIR)
851N/A
493N/A# Directory created by unpacking source, if not set in module makefile
493N/ASOURCE_DIRNAME_DEFAULT = $(SOURCE_DIRNAME_SET:yes=$(POUND_SIGN))
493N/A$(SOURCE_DIRNAME_DEFAULT) SOURCE_DIRNAME=$(MODULE_NAME)-$(MODULE_VERSION)
0N/A
935N/ABUILD_DIR_$(BUILD_TYPE) = build-$(BUILD_TYPE)
922N/A# Special cases for 32-bit & 64-bit directory names to allow building
935N/A# both architectures in the same tree (serially - building both in
922N/A# parallel is likely to have race conditions)
922N/ABUILD_DIR_32 = build-$(MACH32)
922N/ABUILD_DIR_64 = build-$(MACH64)
922N/ABUILD_DIR = $(BUILD_DIR_$(BUILD_TYPE))
922N/A
493N/ASOURCE_DIR = $(BUILD_DIR)/$(SOURCE_DIRNAME)
606N/ASOURCE_DIR_32 = $(BUILD_DIR_32)/$(SOURCE_DIRNAME)
606N/ASOURCE_DIR_64 = $(BUILD_DIR_64)/$(SOURCE_DIRNAME)
90N/A
493N/A# Set default tarball if not set in module makefile
493N/ASOURCE_TARBALL_NAME_DEFAULT = $(SOURCE_TARBALL_NAME_SET:yes=$(POUND_SIGN))
493N/A$(SOURCE_TARBALL_NAME_DEFAULT) SOURCE_TARBALL_NAME=$(SOURCE_DIRNAME).tar.bz2
90N/A
493N/A# Tarballs for most modules built here are found in the X.Org archives/repos
493N/A# in a directory with the same name as what we use in our tree
493N/ASOURCE_TARBALL_DIR_DEFAULT = $(SOURCE_TARBALL_DIR_SET:yes=$(POUND_SIGN))
493N/A$(SOURCE_TARBALL_DIR_DEFAULT) SOURCE_TARBALL_DIR=$(MODTYPE)
0N/A
493N/A# Set default download location if not set in module makefile
493N/ASOURCE_URL_DEFAULT = $(SOURCE_URL_SET:yes=$(POUND_SIGN))
493N/A$(SOURCE_URL_DEFAULT) SOURCE_URL=$(XORG_RELEASES_URL)/$(SOURCE_TARBALL_DIR)/$(SOURCE_TARBALL_NAME)
98N/A
493N/A# Set default git repo location if not set in module makefile
493N/AGIT_URL_DEFAULT = $(GIT_URL_SET:yes=$(POUND_SIGN))
493N/A$(GIT_URL_DEFAULT) GIT_URL=$(XORG_GIT_URL)/$(SOURCE_TARBALL_DIR)/$(MODULE_NAME).git
98N/A
156N/A# Set default build type to 32-bit if not set in module makefile
156N/ABUILD_TYPES_DEFAULT = $(BUILD_TYPES_SET:yes=$(POUND_SIGN))
156N/A$(BUILD_TYPES_DEFAULT) BUILD_TYPES=32
156N/A
493N/A# Set default rules if not set in module/modtype Makefile
493N/ASOURCE_TARGETS_DEFAULT = $(SOURCE_TARGETS_SET:yes=$(POUND_SIGN))
935N/A$(SOURCE_TARGETS_DEFAULT) SOURCE_TARGETS=$(UNPACK_TARGET) \
591N/A $(MODTYPE_ADD_SOURCE_TARGETS) \
591N/A $(MODULE_ADD_SOURCE_TARGETS)
493N/A
493N/ACONFIGURE_TARGETS_DEFAULT = $(CONFIGURE_TARGETS_SET:yes=$(POUND_SIGN))
591N/A$(CONFIGURE_TARGETS_DEFAULT) CONFIGURE_TARGETS=default_configure \
591N/A $(MODTYPE_ADD_CONFIGURE_TARGETS) \
591N/A $(MODULE_ADD_CONFIGURE_TARGETS)
493N/A
493N/ABUILD_TARGETS_DEFAULT = $(BUILD_TARGETS_SET:yes=$(POUND_SIGN))
591N/A$(BUILD_TARGETS_DEFAULT) BUILD_TARGETS=default_build \
591N/A $(MODTYPE_ADD_BUILD_TARGETS) \
591N/A $(MODULE_ADD_BUILD_TARGETS)
493N/A
493N/AINSTALL_TARGETS_DEFAULT = $(INSTALL_TARGETS_SET:yes=$(POUND_SIGN))
591N/A$(INSTALL_TARGETS_DEFAULT) INSTALL_TARGETS=default_install \
591N/A $(MODTYPE_ADD_INSTALL_TARGETS) \
591N/A $(MODULE_ADD_INSTALL_TARGETS)
493N/A
493N/A# Additional flags to pass to make in 32-bit & 64-bit builds
922N/ABUILD_32_FLAGS= ARCH_FLAGS="$(ARCH32_FLAGS)" \
810N/A $(MODTYPE_BUILD_32_FLAGS) $(MODULE_BUILD_32_FLAGS)
810N/A
922N/ABUILD_64_FLAGS= ARCH_FLAGS="$(ARCH64_FLAGS)" \
810N/A $(MODTYPE_BUILD_64_FLAGS) $(MODULE_BUILD_64_FLAGS)
493N/A
922N/Aall: $(BUILD_TYPES:%=build_%)
922N/Aall_%: build_%
0N/A
922N/ACLEAN_RULES = $(BUILD_TYPES:%=clean_%)
922N/Aclean: $(CLEAN_RULES)
922N/A.PARALLEL: $(CLEAN_RULES)
0N/A
922N/A# Remove directories with both styles of naming
922N/A$(CLEAN_RULES):
935N/A -rm -rf $(BUILD_DIR_$(@:clean_%=%)) $(@:clean_%=build_%) $(@:clean_%=build-%)
0N/A
822N/A# Tell dmake not to remove and create source in parallel
822N/A.NOPARALLEL: clean source
822N/A.NOPARALLEL: clean_$(BUILD_TYPE) source_$(BUILD_TYPE)
822N/A
922N/ASOURCE_RULES = $(BUILD_TYPES:%=source_%)
922N/Asource: $(SOURCE_RULES)
922N/A.PARALLEL: $(SOURCE_RULES)
493N/A
922N/Asource-gen: $(SOURCE_TARGETS)
922N/A
922N/A$(SOURCE_RULES):
922N/A $(MAKE) $(MAKEFLAGS) BUILD_TYPE="$(@:source_%=%)" source-gen
493N/A
922N/ACONFIGURE_RULES = $(BUILD_TYPES:%=configure_%)
922N/Aconfigure: $(CONFIGURE_RULES)
922N/A.PARALLEL: $(CONFIGURE_RULES)
493N/A
922N/Aconfigure-gen: source-gen $(CONFIGURE_TARGETS)
493N/A
922N/A$(CONFIGURE_RULES):
922N/A $(MAKE) $(MAKEFLAGS) BUILD_TYPE="$(@:configure_%=%)" \
922N/A $(BUILD_$(@:configure_%=%)_FLAGS) configure-gen
493N/A
922N/ABUILD_RULES = $(BUILD_TYPES:%=build_%)
922N/Abuild: $(BUILD_RULES)
922N/A.PARALLEL: $(BUILD_RULES)
493N/A
922N/Abuild-gen: configure-gen $(BUILD_TARGETS)
0N/A
922N/A$(BUILD_RULES):
922N/A $(MAKE) $(MAKEFLAGS) BUILD_TYPE="$(@:build_%=%)" \
922N/A $(BUILD_$(@:build_%=%)_FLAGS) build-gen
493N/A
922N/AINSTALL_RULES = $(BUILD_TYPES:%=install_%)
922N/Ainstall: $(INSTALL_RULES)
355N/A
922N/Ainstall-gen: build-gen $(INSTALL_TARGETS) install_license install_pkgconfig_uninstalled
0N/A
922N/A$(INSTALL_RULES):
922N/A $(MAKE) $(MAKEFLAGS) BUILD_TYPE="$(@:install_%=%)" \
922N/A $(BUILD_$(@:install_%=%)_FLAGS) install-gen
493N/A
493N/ADEBUG_BUILD_FLAGS = BUILD_DEBUG=yes
0N/A
922N/A# Allow adding "debug-" prefix to rules like build_32, install, etc.
922N/Adebug-%:
922N/A $(MAKE) $(MAKEFLAGS) $(@:debug-%=%) $(DEBUG_BUILD_FLAGS)
493N/A
922N/A# Allow debug_XX to run "make all_XX" with debug flags (including without _XX)
922N/Adebug%:
922N/A $(MAKE) $(MAKEFLAGS) $(@:debug%=all%) $(DEBUG_BUILD_FLAGS)
493N/A
493N/A
493N/A### Source tarballs & downloading if necessary
493N/A
493N/ASOURCE_TARBALL=$(TARBALLDIR)/$(SOURCE_TARBALL_NAME)
493N/A
911N/A# Allow downloading from local archive/mirror
911N/ATARBALL_ARCHIVE_sun.com = http://xserver.sfbay.sun.com/tarballs
911N/ATARBALL_ARCHIVE_DEFAULT = $(TARBALL_ARCHIVE_SET:yes=$(POUND_SIGN))
935N/A$(TARBALL_ARCHIVE_DEFAULT) ARCHIVE_DOMAIN = domainname | awk -F. '{if (NF > 1) {printf "%s.%s", $$(NF-1), $$NF}}'
911N/A$(TARBALL_ARCHIVE_DEFAULT) TARBALL_ARCHIVE = $(TARBALL_ARCHIVE_$(ARCHIVE_DOMAIN:sh))
911N/AARCHIVE_URL=$(TARBALL_ARCHIVE)/$(SOURCE_TARBALL_DIR)/$(SOURCE_TARBALL_NAME)
911N/A
493N/AGIT_CLONE_DIR=$(MODULE_NAME)-$(MODULE_VERSION)
493N/A
493N/A# Download if SOURCE_TARBALL_NAME is not set to NONE and the file either
493N/A# doesn't exist or is empty
705N/A# If MODULE_VERSION is git, checkout source from git repo instead of
493N/A# a tarball
911N/Adownload: $(SOURCE_TARBALL)
911N/A
911N/A$(SOURCE_TARBALL): $(TARBALLDIR)
851N/A @case '$(MAKEFLAGS)' in *[ik]*) set +e;; esac; $(START_CMD_ECHO) ; \
493N/A if [[ "$(MODULE_VERSION)" = "git" ]] ; then \
493N/A if [[ ! -d $(GIT_CLONE_DIR) ]] ; then \
493N/A $(GIT) clone $(GIT_URL) $(GIT_CLONE_DIR) ; \
493N/A if [[ ! -z "$(GIT_BRANCH)" ]] ; then \
493N/A cd $(GIT_CLONE_DIR) && $(GIT) checkout $(GIT_BRANCH) ; \
493N/A fi ; \
493N/A fi ; \
493N/A else \
493N/A if [[ "$(SOURCE_TARBALL_NAME)" != "NONE" ]] ; then \
911N/A if [[ ! -z "$(TARBALL_ARCHIVE)" ]] ; then \
911N/A $(WGET) -O $(SOURCE_TARBALL) $(ARCHIVE_URL) ; \
911N/A else \
493N/A $(WGET) -O $(SOURCE_TARBALL) $(SOURCE_URL) ; \
493N/A fi ; \
493N/A fi ; \
493N/A fi
493N/A
935N/ACHECKSUM_TARGET = .checksum_done.$(MODULE_VERSION)
935N/Acheck-checksums: $(CHECKSUM_TARGET)
935N/A
935N/A$(CHECKSUM_TARGET): $(SOURCE_TARBALL)
911N/A @case '$(MAKEFLAGS)' in *[ik]*) set +e;; esac; \
911N/A if [[ "$(MODULE_VERSION)" != "git" && \
911N/A "$(SOURCE_TARBALL_NAME)" != "NONE" ]] ; then \
911N/A ACTUAL_MD5="$$(digest -a md5 $(SOURCE_TARBALL))" ; \
911N/A if [[ "$${ACTUAL_MD5}" != "${TARBALL_MD5}" ]] ; then \
911N/A print -u2 "ERROR: MD5 sum mismatch on ${SOURCE_TARBALL}\n" \
911N/A "$${ACTUAL_MD5} != ${TARBALL_MD5}" ; \
911N/A exit 1; \
911N/A fi ; \
911N/A ACTUAL_SHA1="$$(digest -a sha1 ${SOURCE_TARBALL})" ; \
911N/A if [[ "$${ACTUAL_SHA1}" != "${TARBALL_SHA1}" ]] ; then \
911N/A print -u2 "ERROR: SHA1 sum mismatch on ${SOURCE_TARBALL}\n" \
911N/A "$${ACTUAL_SHA1} != ${TARBALL_SHA1}" ; \
911N/A exit 1; \
911N/A fi ; \
911N/A fi
935N/A touch $(CHECKSUM_TARGET)
935N/A
935N/Aclean: clean-checksums
935N/A
935N/Aclean-checksums:
935N/A -rm -f .checksum_done.*
911N/A
911N/A
911N/A# Submit a tarball to the archive
911N/AARCHIVE_SUBMIT=/ws/x11/tarballs/bin/archive-tarballs
911N/A
911N/Aarchive-tarball:
911N/A @case '$(MAKEFLAGS)' in *[ik]*) set +e;; esac; \
911N/A if [[ "$(MODULE_VERSION)" != "git" && \
911N/A "$(SOURCE_TARBALL_NAME)" != "NONE" ]] ; then \
911N/A $(ARCHIVE_SUBMIT) \
911N/A --modtype='$(SOURCE_TARBALL_DIR)' \
911N/A --tarball='$(SOURCE_TARBALL_NAME)' \
911N/A --url='$(SOURCE_URL)' \
911N/A --md5='$(TARBALL_MD5)' \
911N/A --sha1='$(TARBALL_SHA1)' ; \
911N/A fi
911N/A
851N/A$(TARBALLDIR):
851N/A mkdir -p $(TARBALLDIR)
851N/A
493N/A# Update a git cloned repo
493N/Agit-update:
493N/A if [[ "$(MODULE_VERSION)" = "git" ]] ; then \
493N/A if [[ -d $(GIT_CLONE_DIR) ]] ; then \
493N/A cd $(GIT_CLONE_DIR) ; \
493N/A if [[ ! -z "$(GIT_BRANCH)" ]] ; then \
493N/A $(GIT) checkout master && \
493N/A $(GIT) fetch && \
493N/A $(GIT) checkout $(GIT_BRANCH) ; \
493N/A else \
493N/A $(GIT) fetch ; \
493N/A fi ; \
493N/A fi ; \
493N/A fi
493N/A
0N/A
0N/A### Unpack source and apply patches
0N/A
935N/A# Step 1: Initialize source dir with upstream sources
935N/A# - if there's a tarball, unpack it.
935N/A# - if using a git master, copy it.
935N/ASOURCE_INIT_TARGET_FILE=.source.init.done
935N/ASOURCE_INIT_TARGET=$(SOURCE_DIR)/$(SOURCE_INIT_TARGET_FILE)
935N/Ainit_source: $(SOURCE_INIT_TARGET)
90N/A
935N/A$(SOURCE_INIT_TARGET):
0N/A mkdir -p $(BUILD_DIR)
935N/A @ if [[ "$(SOURCE_TARBALL_NAME)" == "NONE" ]] ; then \
935N/A $(START_CMD_ECHO); mkdir -p $(SOURCE_DIR) ; \
935N/A else \
493N/A if [[ "$(MODULE_VERSION)" = "git" ]] ; then \
493N/A SOURCE_CMD='gtar --exclude=.git* -cf - $(GIT_CLONE_DIR)' ; \
493N/A else \
493N/A UNCOMP_CMD="$(SOURCE_UNCOMPRESS)" ; \
493N/A SOURCE_CMD="$${UNCOMP_CMD:-bzcat} $(SOURCE_TARBALL)" ; \
493N/A fi ; \
935N/A $(START_CMD_ECHO) ; \
935N/A $${SOURCE_CMD} | \
935N/A gtar --directory="$(BUILD_DIR)" $(ADD_TAR_FLAGS) -xf - ; \
935N/A fi
935N/A touch $(SOURCE_INIT_TARGET)
935N/A
935N/A# Step 2: Add in any additional local sources from $(ADDITIONAL_SOURCE_DIR)
935N/A# (done after init source to avoid races in directory/file creation)
935N/ASOURCE_ADD_TARGET_FILE=.source.add.done
935N/ASOURCE_ADD_TARGET=$(SOURCE_DIR)/$(SOURCE_ADD_TARGET_FILE)
935N/Aadd_source: $(SOURCE_ADD_TARGET)
935N/A
935N/A$(SOURCE_ADD_TARGET): $(SOURCE_INIT_TARGET)
935N/A @if [[ "$(ADDITIONAL_SOURCE_DIR)" != "" ]] ; then \
493N/A if [[ ! -x $(LNDIR) ]] ; then \
493N/A (cd $(TOP)/util/lndir && $(MAKE) $(MAKEFLAGS) install) ; \
493N/A fi ; \
935N/A $(START_CMD_ECHO) ; \
935N/A cd $(SOURCE_DIR) && $(LNDIR) ../../$(ADDITIONAL_SOURCE_DIR) ; \
935N/A fi
935N/A touch $(SOURCE_ADD_TARGET)
935N/A
935N/A# Step 3: Apply any local patches (may be done in parallel to add_source,
935N/A# but must come after init_source is finished)
935N/A#
935N/A# SOURCE_PATCHES is a list in the format: filename[,flags]
935N/A# $${p/*,} is ksh93 syntax to remove the comma and everything before it in $p
935N/A# $${p%,*} is ksh93 syntax to remove the comma and everything after it in $p
935N/APATCHED_TARGET_FILE=.patches.done
935N/APATCHED_TARGET=$(SOURCE_DIR)/$(PATCHED_TARGET_FILE)
935N/Apatched_source: $(PATCHED_TARGET)
935N/A
935N/A$(PATCHED_TARGET): $(SOURCE_INIT_TARGET)
935N/A @ if [[ "$(SOURCE_PATCHES)" != "" ]] ; then \
0N/A for p in $(SOURCE_PATCHES) x ; do \
493N/A if [[ "$$p" != "x" ]] ; then \
922N/A patch_file="$${p%,*}" ; \
922N/A if [[ "$$p" =~ "," ]] ; then \
922N/A patch_flags="$${p/*,}" ; \
922N/A else \
922N/A patch_flags="-p0" ; \
922N/A fi ; \
922N/A ($(START_CMD_ECHO) ; \
922N/A gpatch -d $(SOURCE_DIR) $${patch_flags} < "$${patch_file}" ) ; \
0N/A fi ; \
0N/A done ; \
935N/A fi
935N/A touch $(PATCHED_TARGET)
935N/A
935N/A# Step 4: Apply common Solaris changes to man pages in $(SUNTOUCHED_MANPAGES)
947N/AFIXED_MAN_SUFFIX=mantouch.done
947N/AFIXED_MAN_TARGET=$(SUNTOUCHED_MANPAGES:%=$(SOURCE_DIR)/%.$(FIXED_MAN_SUFFIX))
935N/Afixed_man: $(FIXED_MAN_TARGET)
935N/A
935N/ACOMMON_SUNTOUCH_MAN_FLAGS = \
935N/A -a '{Availability, $(SUN_PACKAGE)}' \
935N/A -a '{Interface Stability, $(MODULE_STABILITY)}'
935N/A
947N/ADEFAULT_SUNTOUCH_MAN_FLAGS = \
935N/A $(COMMON_SUNTOUCH_MAN_FLAGS) \
935N/A $(MODTYPE_SUNTOUCH_MAN_FLAGS) \
935N/A $(MODULE_SUNTOUCH_MAN_FLAGS)
935N/A
947N/ASUNTOUCH_MAN_FLAGS_DEFAULT = $(SUNTOUCH_MAN_FLAGS_SET:yes=$(POUND_SIGN))
947N/A$(SUNTOUCH_MAN_FLAGS_DEFAULT) SUNTOUCH_MAN_FLAGS = $(DEFAULT_SUNTOUCH_MAN_FLAGS)
947N/A
947N/A$(FIXED_MAN_TARGET): $(PATCHED_TARGET) $(SOURCE_ADD_TARGET)
947N/A $(PERL) $(TOP)/common/suntouch-manpages.pl $(SUNTOUCH_MAN_FLAGS) \
947N/A $(@:%.$(FIXED_MAN_SUFFIX)=%)
947N/A touch $@
935N/A
935N/A# Step 5: Apply common Solaris changes to pkg-config *.pc files listed in
935N/A# $(FIX_PC_FILES)
935N/ASOURCE_PC_FILES = $(FIX_PC_FILES:%=$(SOURCE_DIR)/%)
935N/AORIG_PC_FILES = $(SOURCE_PC_FILES:%=%.orig)
935N/AFIXED_PC_TARGET = $(ORIG_PC_FILES)
935N/Afixed_pc: $(FIXED_PC_TARGET)
935N/A
935N/AFIX_PC_OPS= \
935N/A -e 's|-L\$${libdir}|-L\$${libdir} -R\$${libdir}|;' \
935N/A -e 's|Requires.private: .*$$||;' \
935N/A $(MODTYPE_FIX_PC_FLAGS) \
935N/A $(MODULE_FIX_PC_FLAGS)
935N/A
935N/A$(ORIG_PC_FILES): $(PATCHED_TARGET)
935N/A $(PERL) -i.orig -p $(FIX_PC_OPS) $(@:.orig=)
935N/A
935N/A# Tie them all together
935N/ASOURCE_DEPS = $(SOURCE_TARBALL) $(MODTYPE_SOURCE_DEPS) $(MODULE_SOURCE_DEPS)
935N/A
935N/AUNPACK_TARGETS = $(SOURCE_INIT_TARGET) $(PATCHED_TARGET) \
935N/A $(SOURCE_ADD_TARGET) $(FIXED_MAN_TARGET) $(FIXED_PC_TARGET)
935N/A
935N/Adefault_source: $(UNPACK_TARGET)
935N/A
935N/A$(UNPACK_TARGET): $(SOURCE_DEPS) $(UNPACK_TARGETS)
606N/A touch $(UNPACK_TARGET)
0N/A
493N/A### Run configure scripts
191N/A
191N/A# Include Xorg autoconf macros when rebuilding configure scripts
599N/A# and use automake 1.10 instead of the older 1.9.
599N/A# /opt/jdsbld/share/aclocal is needed to get the nls.m4 from CBEgettext
599N/A# due to: 6785384 SUNWgnu-gettext does not include autoconf m4 files
935N/AACLOCAL_PATH=/usr/bin/aclocal-1.10
599N/AACLOCAL_INCLUDES = -I $(PROTODIR)$(X11_ACLOCAL_DIR) \
599N/A -I /usr/share/aclocal -I /usr/share/aclocal-1.10 \
599N/A -I /opt/jdsbld/share/aclocal
599N/AAUTOMAKE_PATH=/usr/bin/automake-1.10
599N/AAUTORECONF_ENV= ACLOCAL="$(ACLOCAL_PATH) $(ACLOCAL_INCLUDES)" \
599N/A AUTOMAKE="$(AUTOMAKE_PATH)"
493N/A
493N/A# Dependencies for running configure to make a Makefile
922N/ACONFIGURE_DEPS = $(SOURCE_TARGETS) \
493N/A $(MODTYPE_CONFIGURE_DEPS) $(MODULE_CONFIGURE_DEPS)
493N/A
493N/A# Command line options to GNU autoconf configure script
493N/ADEFAULT_CONFIG_OPTS = --prefix=$(MODULE_PREFIX) \
810N/A --mandir='$${prefix}/share/man' --localstatedir=/var
493N/A
493N/ACONFIG_OPTS = $(DEFAULT_CONFIG_OPTS) \
493N/A $(MODTYPE_CONFIG_OPTS) $(MODULE_CONFIG_OPTS)
493N/A
493N/A# Environment variable options to GNU autoconf configure script
493N/A$(USE_DEFAULT_CONFIG_CPPFLAGS:no=$(POUND_SIGN)) DEFAULT_CONFIG_CPPFLAGS= \
494N/A -I$(PROTODIR)$(X11_INCLUDES_DIR) \
494N/A -I$(PROTODIR)/usr/include -I$(PROTODIR)/usr/include/freetype2
493N/A$(USE_DEFAULT_CONFIG_LDFLAGS:no=$(POUND_SIGN)) DEFAULT_CONFIG_LDFLAGS= \
493N/A -L$(PROTODIR)/usr/lib$(ARCHLIBSUBDIR) \
493N/A -L$(PROTODIR)$(X11_DIR)/lib$(ARCHLIBSUBDIR)
561N/A
851N/ADEFAULT_PKG_CONFIG_PATH=$(TOP)/common/pc-files/$(BUILD_DIR):$(PROTODIR)$(PKGCONFIG_DIR):$(PROTODIR)$(PKGCONFIG_DIR_SHARE):$(PKGCONFIG_DIR):$(PKGCONFIG_DIR_SHARE)
191N/A
493N/A# Set USE_DEFAULT_CONFIG_ENV=no in a Makefile to not use this default
493N/A# autoconfig environment
493N/A$(USE_DEFAULT_CONFIG_ENV:no=$(POUND_SIGN)) DEFAULT_CONFIG_ENV = \
493N/A CC="$(CC)" CXX="$(CXX)" \
493N/A LD="$(CC) $(LDFLAGS)" \
493N/A CFLAGS="$(MODTYPE_CFLAGS) $(MODULE_CFLAGS)" \
493N/A CXXFLAGS="$(MODTYPE_CXXFLAGS) $(MODULE_CXXFLAGS)" \
493N/A CPPFLAGS="$(DEFAULT_CONFIG_CPPFLAGS) $(MODTYPE_CPPFLAGS) $(MODULE_CPPFLAGS)" \
493N/A LDFLAGS="$(DEFAULT_CONFIG_LDFLAGS) $(MODTYPE_CFLAGS) $(MODTYPE_LDFLAGS) $(MODULE_CFLAGS) $(MODULE_LDFLAGS)" \
493N/A PKG_CONFIG_PATH="$(DEFAULT_PKG_CONFIG_PATH)" \
493N/A INSTALL="$(INSTALL_SCRIPT)" CPPROG="cp -p" \
493N/A MAKE="$(MODULE_MAKE)" CONFIG_SHELL="$(SHELL)"
493N/A
493N/ACONFIG_ENV = $(DEFAULT_CONFIG_ENV) $(MODTYPE_CONFIG_ENV) $(MODULE_CONFIG_ENV)
493N/A
493N/A# File created by running configure - defaults to the top-level Makefile
493N/A# in a source directory unless AUTOCONF_TARGET_SET=yes is set
493N/AAUTOCONF_TARGET_DEFAULT = $(AUTOCONF_TARGET_SET:yes=$(POUND_SIGN))
493N/A$(AUTOCONF_TARGET_DEFAULT) AUTOCONF_TARGET=$(SOURCE_DIR)/Makefile
493N/A
493N/A$(AUTOCONF_TARGET): $(CONFIGURE_DEPS)
493N/A cd $(SOURCE_DIR) ; \
705N/A if [[ "$(AUTORECONF)" = "yes" || "$(MODULE_VERSION)" = "git" ]] ; then \
599N/A $(AUTORECONF_ENV) autoreconf -v --install --force ; \
493N/A fi ; \
493N/A chmod a+x configure ; \
493N/A $(CONFIG_ENV) $(SHELL) ./configure $(CONFIG_OPTS) ; \
493N/A if [[ "$(DELIBTOOLIZE)" = "yes" ]] ; then \
493N/A $(TOP)/common/delibtoolize.pl $(DELIBTOOLIZE_FLAGS) . ; \
493N/A fi
493N/A
910N/Adefault_configure: $(AUTOCONF_TARGET)
493N/A
0N/A
957N/A# Additional rule used in xserver/Makefile.inc & driver/Makefile.inc to
957N/A# edit the Makefiles generated by configure to override module subdirs
957N/A# for 64-bit x86 modules to be modules/xxx/amd64, not modules/amd64/xxx
957N/AFIXEDMODS_TARGET = $(AUTOCONF_TARGET).fixedmods
957N/ACONFIGURE_FIXEDMODS_/amd64 = $(FIXEDMODS_TARGET)
957N/ACONFIGURE_FIXEDMODS_TARGET = $(CONFIGURE_FIXEDMODS_$(SERVERMOD_subdir))
957N/A
957N/Afix-moduledirs: $(CONFIGURE_FIXEDMODS_TARGET)
957N/A
957N/AFIXEDMODS_SUBSTS = \
957N/A-e 's{\$$\(moduledir\)/(\w+|\$$\(\w+\))}{$(X11_SERVERMODS_DIR)/$$1$(SERVERMOD_subdir)}g;' \
957N/A-e 's{$(X11_SERVERMODS_DIR)$(SERVERMOD_subdir)/([^\s/]+)}{$(X11_SERVERMODS_DIR)/$$1$(SERVERMOD_subdir)}g;'
957N/A
957N/A$(FIXEDMODS_TARGET): $(AUTOCONF_TARGET)
957N/A find $(SOURCE_DIR) -name Makefile | \
957N/A xargs $(PERL) -i.orig -p $(FIXEDMODS_SUBSTS)
957N/A
957N/A
493N/A### Default rules for common build pattern
493N/A
493N/ALD_OPTIONS = -L$(PROTODIR)$(X11_DIR)/lib$(LIBSUBDIR) \
493N/A $(MODTYPE_LD_OPTIONS) $(MODULE_LD_OPTIONS)
493N/A
810N/A# MKDIRPROG - Workaround parallel build race condition
810N/A# in older upstream packaged install-sh
810N/A
536N/ABUILD_ENV = LD_OPTIONS='$(LD_OPTIONS)' \
606N/A PROTODIR='$(PROTODIR)' \
810N/A MAKE='$(MODULE_MAKE)' \
810N/A MKDIRPROG='mkdir -p' \
493N/A $(MODTYPE_BUILD_ENV) $(MODULE_BUILD_ENV)
493N/A
493N/ADEFAULT_BUILD_MAKEFLAGS=$(MODTYPE_MAKEFLAGS) $(MODULE_MAKEFLAGS) \
493N/A $(MODTYPE_BUILD_MAKEFLAGS) $(MODULE_BUILD_MAKEFLAGS)
493N/A
922N/A# Dependencies for make build step
922N/ABUILD_DEPS = $(SOURCE_TARGETS) $(CONFIGURE_TARGETS) $(MODTYPE_BUILD_DEPS) $(MODULE_BUILD_DEPS) $(MODULE_MAKE)
922N/A
922N/Adefault_build: $(BUILD_DEPS)
493N/A (cd $(SOURCE_DIR) ; \
493N/A $(BUILD_ENV) $(MODULE_MAKE) $(MAKEFLAGS) $(DEFAULT_BUILD_MAKEFLAGS))
493N/A
493N/Aprint_default_build_flags:
493N/A @print "BUILD_ENV='$(BUILD_ENV)'" ; \
493N/A print "MAKE='$(MODULE_MAKE)'" ; \
810N/A print "MAKEFLAGS='$(MAKEFLAGS) $(DEFAULT_BUILD_MAKEFLAGS)'"
493N/A
493N/Abuild-in-subdir:
493N/A (cd $(subdir) ; \
493N/A $(BUILD_ENV) $(MODULE_MAKE) $(MAKEFLAGS) $(DEFAULT_BUILD_MAKEFLAGS) \
493N/A $(subdir_cmd) )
493N/A
493N/ADEFAULT_INSTALL_MAKEFLAGS= -e DESTDIR=$(PROTODIR) \
851N/A pkgconfigdir=$(MODULE_PKGCONFIG_DIR) \
493N/A $(MODTYPE_MAKEFLAGS) $(MODULE_MAKEFLAGS) \
493N/A $(MODTYPE_INSTALL_MAKEFLAGS) $(MODULE_INSTALL_MAKEFLAGS) \
493N/A
591N/A# Dependencies for make install step
591N/AINSTALL_DEPS = $(BUILD_TARGETS) $(MODTYPE_INSTALL_DEPS) $(MODULE_INSTALL_DEPS)
591N/A
910N/Adefault_install: $(INSTALL_DEPS)
493N/A (cd $(SOURCE_DIR) ; \
493N/A $(BUILD_ENV) $(MODULE_MAKE) $(MAKEFLAGS) $(DEFAULT_INSTALL_MAKEFLAGS) \
493N/A install)
493N/A
493N/Aprint_default_install_flags:
493N/A @print "BUILD_ENV='$(BUILD_ENV)'" ; \
493N/A print "MAKE='$(MODULE_MAKE)'" ; \
493N/A print "MAKE_FLAGS='$(MAKEFLAGS) $(DEFAULT_INSTALL_MAKEFLAGS)'"
493N/A
935N/Ainstall-in-subdir:
493N/A (cd $(subdir) ; \
493N/A $(BUILD_ENV) $(MODULE_MAKE) $(MAKEFLAGS) $(DEFAULT_INSTALL_MAKEFLAGS) \
493N/A $(subdir_cmd))
493N/A
606N/A# Adjust paths in pkg-config files for -uninstalled variants used during build
606N/AUNINSTALLED_PC_OPS= \
705N/A -e 'BEGIN {use Cwd; $$protodir=Cwd::realpath("$(PROTODIR)");}' \
705N/A -e 's|(-[LI]\s*)\$$|$$1$$protodir\$$|g;' \
705N/A -e 's|^sdkdir=|sdkdir=$$protodir|g;' \
837N/A -e 's|$$protodir\$${sdkdir}|\$${sdkdir}|g;' \
837N/A $(MODTYPE_ADD_UNINSTALLED_PC_OPS) $(MODULE_ADD_UNINSTALLED_PC_OPS)
606N/A
910N/AINSTALL_PCU_DEPS_DEFAULT = $(INSTALL_PCU_DEPS_SET:yes=$(POUND_SIGN))
910N/A$(INSTALL_PCU_DEPS_DEFAULT) INSTALL_PCU_DEPS = $(INSTALL_TARGETS)
910N/A
910N/Ainstall_pkgconfig_uninstalled: $(INSTALL_PCU_DEPS)
606N/A @ if [[ ! -z "$(FIX_PC_FILES)" ]] ; then \
606N/A cd $(SOURCE_DIR) ; \
606N/A for pcin in $(FIX_PC_FILES:.in=) ; do \
606N/A pc=$${pcin%%+(.pc|.in)} ; \
851N/A ($(START_CMD_ECHO) ; \
935N/A $(PERL) -p $(UNINSTALLED_PC_OPS) $$pc.pc > \
851N/A $(PROTODIR)$(MODULE_PKGCONFIG_DIR)/$$(basename $${pc})-uninstalled.pc ) ; \
606N/A done ; \
606N/A fi
606N/A
591N/A# Set comments in ELF binaries to help identify versions/builds
591N/AELF_COMMENTS = $(MODULE_NAME) $(MODULE_VERSION)
591N/AELF_COMMENTS += $(MODTYPE_ELF_COMMENTS)$(MODULE_ELF_COMMENTS)
591N/A
705N/A$(BUILD_DEBUG:yes=) DEBUG_ELF_COMMENTS=(DEBUG)
705N/A$(BUILD_DEBUG:yes=$(POUND_SIGN)) DEBUG_ELF_COMMENTS=
705N/AELF_COMMENTS += $(DEBUG_ELF_COMMENTS)
705N/A
810N/Aset-elf-comments: $(BUILD_TARGETS:set-elf-comments=)
906N/A $(TOP)/common/set-elf-comments.pl -B 'hg id' \
591N/A -M '$(ELF_COMMENTS)' $(SOURCE_DIR)
591N/A
493N/A
493N/A### Other tools/dependencies needed to build
0N/A
0N/A# Some modules (such as FreeType 2) require GNU make
493N/A$(GNUMAKE):
493N/A @print -n "Building with GNU make from $$(whence gmake): "
493N/A @$(GNUMAKE) --version
0N/A
493N/A$(MAKE):
493N/A @print "Building with make from $$(whence $(MAKE))"
0N/A
90N/A# Some modules use lndir to merge in sources from Sun specific directories
90N/A$(LNDIR):
493N/A (cd $(TOP)/util/lndir && $(MAKE) $(MAKEFLAGS) install)
90N/A
493N/A# Some modules use these tools to convert DocBook docs to text or html
822N/A$(DOCBOOK2HTML) + $(DOCBOOK2TEXT):
493N/A cd $(TOP)/doc/docbook-utils && $(MAKE) $(MAKEFLAGS) install
98N/A
493N/A$(XORG_DEFS_ENT):
493N/A cd $(TOP)/doc/xorg-sgml-doctools && $(MAKE) $(MAKEFLAGS) install
0N/A
47N/A### Useful rules for maintaining patch sets
47N/A
47N/A# regenerate patches against new baseline to reduce messages about hunks
47N/A# having fuzz or offsets when applying patches - new patches will be in new/
47N/A
935N/Aregen-patches:
47N/A CUR_LIST=""
47N/A rm -rf tmp-regen
935N/A $(MAKE) SOURCE_PATCHES="$(CUR_LIST)" BUILD_DIR=tmp-regen patched_source
47N/A mkdir -p new
47N/A for f in $(SOURCE_PATCHES) ; do \
922N/A p=$${f%,*} ; \
493N/A print '=================' $$p ; \
47N/A rm -rf prev ; \
47N/A mv tmp-regen prev ; \
935N/A $(MAKE) SOURCE_PATCHES="$${CUR_LIST} $$f" BUILD_DIR=tmp-regen patched_source ; \
935N/A gawk '/^--- / {exit} \
935N/A /^diff -u/ {exit} \
90N/A {print}' $$p > new/$$p ; \
98N/A gdiff -urp -x '*~' -x '*.orig' ./prev ./tmp-regen \
922N/A | sed -e 's% \./prev/$(SOURCE_DIRNAME)/% %' -e 's% \./tmp-regen/$(SOURCE_DIRNAME)/% %' \
47N/A | grep -v '^Common subdirectories:' \
47N/A | grep -v '^Only in ' \
90N/A >> new/$$p ; \
90N/A CUR_LIST="$${CUR_LIST} new/$$p" ; \
47N/A done
47N/A rm -rf tmp-regen
355N/A
922N/A# Derive directory name relative to open-src
922N/ATHIS_MODULE:sh=echo ${PWD} | sed 's|.*/open-src/||'
922N/A
935N/A# Allows running "make list-patches" to get a list of all patches we
606N/A# currently apply in our builds
606N/Alist-patches:
922N/A @if [[ "$(SOURCE_PATCHES)" != "" ]] ; then \
606N/A for p in $(SOURCE_PATCHES) x ; do \
606N/A if [[ "$$p" != "x" ]] ; then \
922N/A print "$(THIS_MODULE)/$${p%,*}" ; \
606N/A fi ; \
606N/A done ; \
606N/A fi
606N/A
355N/A### Licensing files
355N/A
355N/A# Default license file name is COPYING (X.Org & GNU autoconf default)
355N/A# For other license file names, set LICENSE_FILE to the file name
355N/A# and set LICENSE_FILE_SET=yes
387N/A# A file in the same directory as the Makefile takes precedence
387N/A# over one that is delivered in the package.
355N/ALICENSE_FILE_DEFAULT = $(LICENSE_FILE_SET:yes=$(POUND_SIGN))
355N/A$(LICENSE_FILE_DEFAULT) LICENSE_FILE=COPYING
355N/A
922N/AMODULE_LICENSE_DESTDIR = $(LICENSE_DEST)/$(THIS_MODULE)
922N/A
922N/Ainstall_license: $(MODULE_LICENSE_DESTDIR)/COPYING
922N/A
922N/A$(MODULE_LICENSE_DESTDIR):
922N/A mkdir -p $@
922N/A
922N/A$(MODULE_LICENSE_DESTDIR)/COPYING: $(MODULE_LICENSE_DESTDIR) $(SOURCE_TARGETS)
922N/A @ $(START_CMD_ECHO) ; \
493N/A if [[ -f $(LICENSE_FILE) ]] ; then \
493N/A LICENSE_TO_COPY="$(LICENSE_FILE)" ; \
493N/A elif [[ -f $(SOURCE_DIR)/$(LICENSE_FILE) ]] ; then \
493N/A LICENSE_TO_COPY="$(SOURCE_DIR)/$(LICENSE_FILE)" ; \
493N/A fi ; \
493N/A if [[ "$${LICENSE_TO_COPY}" != "" ]] ; then \
922N/A rm -f $@ ; \
922N/A cp -pf $${LICENSE_TO_COPY} $@ ; \
355N/A fi
935N/A
935N/A# For use in debugging or calling from scripts like the code review helper
935N/A# Use such as: make print_make_vars VARS="MODTYPE MODULE_NAME"
935N/A# or: make print_make_var BUILD_TYPE=32 VARS=SOURCE_DIR
935N/Aprint_make_var-%:
935N/A @print -n ' $(@:print_make_var-%=%)="$($(@:print_make_var-%=%))"'
935N/A
935N/Aprint_make_vars: $(VARS:%=print_make_var-%)
935N/A @print '\n'