From 4cd8bdc969b53bc34746ace674edd8d0d32c0fde Mon Sep 17 00:00:00 2001 From: Brian Anderson Date: Wed, 12 Feb 2014 17:26:10 -0800 Subject: [PATCH] mk: Add prepare.mk This is a slightly more generic rewrite of install.mk. Currently used for nothing, but we'll base all the binary distributables off it. --- Makefile.in | 33 +++++---- mk/prepare.mk | 181 ++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 201 insertions(+), 13 deletions(-) create mode 100644 mk/prepare.mk diff --git a/Makefile.in b/Makefile.in index 43abb2736762..65c3d6267834 100644 --- a/Makefile.in +++ b/Makefile.in @@ -198,13 +198,6 @@ include $(CFG_SRC_DIR)mk/llvm.mk # Secondary makefiles, conditionalized for speed ###################################################################### -# Source and binary distribution artifacts -ifneq ($(strip $(findstring dist,$(MAKECMDGOALS)) \ - $(findstring clean,$(MAKECMDGOALS))),) - CFG_INFO := $(info cfg: including dist rules) - include $(CFG_SRC_DIR)mk/dist.mk -endif - # Binary snapshots ifneq ($(strip $(findstring snap,$(MAKECMDGOALS)) \ $(findstring clean,$(MAKECMDGOALS))),) @@ -227,18 +220,32 @@ ifneq ($(findstring perf,$(MAKECMDGOALS)),) include $(CFG_SRC_DIR)mk/perf.mk endif +# Copy all the distributables to another directory for binary install +ifneq ($(strip $(findstring prepare,$(MAKECMDGOALS)) \ + $(findstring install,$(MAKECMDGOALS))),) + CFG_INFO := $(info cfg: including prepare rules) + include $(CFG_SRC_DIR)mk/prepare.mk +endif + +# (Unix) Installation from the build directory +ifneq ($(findstring install,$(MAKECMDGOALS)),) + CFG_INFO := $(info cfg: including install rules) + include $(CFG_SRC_DIR)mk/install.mk +endif + +# Source and binary distribution artifacts +ifneq ($(strip $(findstring dist,$(MAKECMDGOALS)) \ + $(findstring clean,$(MAKECMDGOALS))),) + CFG_INFO := $(info cfg: including dist rules) + include $(CFG_SRC_DIR)mk/dist.mk +endif + # Cleaning ifneq ($(findstring clean,$(MAKECMDGOALS)),) CFG_INFO := $(info cfg: including clean rules) include $(CFG_SRC_DIR)mk/clean.mk endif -# Installation from the build directory -ifneq ($(findstring install,$(MAKECMDGOALS)),) - CFG_INFO := $(info cfg: including install rules) - include $(CFG_SRC_DIR)mk/install.mk -endif - # CTAGS building ifneq ($(strip $(findstring TAGS.emacs,$(MAKECMDGOALS)) \ $(findstring TAGS.vi,$(MAKECMDGOALS))),) diff --git a/mk/prepare.mk b/mk/prepare.mk new file mode 100644 index 000000000000..0d3d7c34a941 --- /dev/null +++ b/mk/prepare.mk @@ -0,0 +1,181 @@ +# Copyright 2014 The Rust Project Developers. See the COPYRIGHT +# file at the top-level directory of this distribution and at +# http://rust-lang.org/COPYRIGHT. +# +# Licensed under the Apache License, Version 2.0 or the MIT license +# , at your +# option. This file may not be copied, modified, or distributed +# except according to those terms. + +# Basic support for producing installation images. +# +# The 'prepare' build target copies all release artifacts from the build +# directory to some other location, placing all binaries, libraries, and +# docs in their final locations relative to each other. +# +# It requires the following variables to be set: +# +# PREPARE_HOST - the host triple +# PREPARE_TARGETS - the target triples, space separated +# PREPARE_DEST_DIR - the directory to put the image + +prepare: PREPARE_STAGE=2 +prepare: PREPARE_DIR_CMD=$(DEFAULT_PREPARE_DIR_CMD) +prepare: PREPARE_BIN_CMD=$(DEFAULT_PREPARE_BIN_CMD) +prepare: PREPARE_LIB_CMD=$(DEFAULT_PREPARE_LIB_CMD) +prepare: PREPARE_MAN_CMD=$(DEFAULT_PREPARE_MAN_CMD) +prepare: prepare-base + +prepare-base: PREPARE_SOURCE_DIR=$(PREPARE_HOST)/stage$(PREPARE_STAGE) +prepare-base: PREPARE_SOURCE_BIN_DIR=$(PREPARE_SOURCE_DIR)/bin +prepare-base: PREPARE_SOURCE_LIB_DIR=$(PREPARE_SOURCE_DIR)/$(CFG_LIBDIR_RELATIVE) +prepare-base: PREPARE_SOURCE_MAN_DIR=$(S)/man +prepare-base: PREPARE_DEST_BIN_DIR=$(PREPARE_DEST_DIR)/bin +prepare-base: PREPARE_DEST_LIB_DIR=$(PREPARE_DEST_DIR)/$(CFG_LIBDIR_RELATIVE) +prepare-base: PREPARE_DEST_MAN_DIR=$(PREPARE_DEST_DIR)/man1 +prepare-base: prepare-host prepare-targets + +DEFAULT_PREPARE_DIR_CMD = umask 022 && mkdir -p +DEFAULT_PREPARE_BIN_CMD = install -m755 +DEFAULT_PREPARE_LIB_CMD = install -m644 +DEFAULT_PREPARE_MAN_CMD = install -m755 + +# On windows we install from stage3, but on unix only stage2 +# Because of the way these rules are organized, preparing from any +# stage requires all these stages to be built +ifdef CFG_WINDOWSY_$(CFG_BUILD) +PREPARE_STAGES=1 2 3 +else +PREPARE_STAGES=1 2 +endif + +# Create a directory +# $(1) is the directory +define PREPARE_DIR + @$(Q)$(call E, install: $(1)) + $(Q)$(PREPARE_DIR_CMD) $(1) +endef + +# Copy an executable +# $(1) is the filename/libname-glob +define PREPARE_BIN + @$(call E, install: $(PREPARE_DEST_BIN_DIR)/$(1)) + $(Q)$(PREPARE_BIN_CMD) $(PREPARE_SOURCE_BIN_DIR)/$(1) $(PREPARE_DEST_BIN_DIR)/$(1) +endef + +# Copy a dylib or rlib +# $(1) is the filename/libname-glob +# +# XXX: Don't remove the $(nop) command below! +# Yeah, that's right, it's voodoo. Something in the way this macro is being expanded +# causes it to parse incorrectly. Throwing in that empty command seems to fix the +# problem. I'm sorry, just don't remove the $(nop), alright? +define PREPARE_LIB + $(nop) + @$(call E, install: $(PREPARE_WORKING_DEST_LIB_DIR)/$(1)) + $(Q)LIB_NAME="$(notdir $(lastword $(wildcard $(PREPARE_WORKING_SOURCE_LIB_DIR)/$(1))))"; \ + MATCHES="$(filter-out %$(notdir $(lastword $(wildcard $(PREPARE_WORKING_SOURCE_LIB_DIR)/$(1)))),\ + $(wildcard $(PREPARE_WORKING_DEST_LIB_DIR)/$(1)))"; \ + if [ -n "$$MATCHES" ]; then \ + echo "warning: one or libraries matching Rust library '$(1)'" && \ + echo " (other than '$$LIB_NAME' itself) already present" && \ + echo " at destination $(PREPARE_WORKING_DEST_LIB_DIR):" && \ + echo $$MATCHES ; \ + fi + $(Q)$(PREPARE_LIB_CMD) `ls -drt1 $(PREPARE_WORKING_SOURCE_LIB_DIR)/$(1) | tail -1` $(PREPARE_WORKING_DEST_LIB_DIR)/ +endef + +# Copy a man page +# $(1) - source dir +define PREPARE_MAN + @$(call E, install: $(PREPARE_DEST_MAN_DIR)/$(1)) + $(Q)$(PREPARE_MAN_CMD) $(PREPARE_SOURCE_MAN_DIR)/$(1) $(PREPARE_DEST_MAN_DIR)/$(1) +endef + + +PREPARE_TOOLS = $(filter-out compiletest, $(TOOLS)) + +prepare-host: prepare-host-dirs prepare-host-tools + +prepare-host-dirs: + $(call PREPARE_DIR,$(PREPARE_DEST_BIN_DIR)) + $(call PREPARE_DIR,$(PREPARE_DEST_LIB_DIR)) + $(call PREPARE_DIR,$(PREPARE_DEST_MAN_DIR)) + +prepare-host-tools:\ + $(foreach tool, $(PREPARE_TOOLS),\ + $(foreach stage,$(PREPARE_STAGES),\ + $(foreach host,$(CFG_HOST),\ + prepare-host-tool-$(tool)-$(stage)-$(host)))) + +# $(1) is tool +# $(2) is stage +# $(3) is host +define DEF_PREPARE_HOST_TOOL +prepare-host-tool-$(1)-$(2)-$(3): $$(foreach dep,$$(TOOL_DEPS_$(1)),prepare-host-lib-$$(dep)-$(2)-$(3)) \ + $$(HBIN$(2)_H_$(3))/$(1)$$(X_$(3)) + $$(if $$(findstring $(2), $$(PREPARE_STAGE)),\ + $$(if $$(findstring $(3), $$(PREPARE_HOST)),\ + $$(call PREPARE_BIN,$(1)$$(X_$$(PREPARE_HOST))),),) + $$(if $$(findstring $(2), $$(PREPARE_STAGE)),\ + $$(if $$(findstring $(3), $$(PREPARE_HOST)),\ + $$(call PREPARE_MAN,$(1).1),),) +endef + +$(foreach tool,$(PREPARE_TOOLS),\ + $(foreach stage,$(PREPARE_STAGES),\ + $(foreach host,$(CFG_HOST),\ + $(eval $(call DEF_PREPARE_HOST_TOOL,$(tool),$(stage),$(host)))))) + +# $(1) is tool +# $(2) is stage +# $(3) is host +define DEF_PREPARE_HOST_LIB +prepare-host-lib-$(1)-$(2)-$(3): PREPARE_WORKING_SOURCE_LIB_DIR=$$(PREPARE_SOURCE_LIB_DIR) +prepare-host-lib-$(1)-$(2)-$(3): PREPARE_WORKING_DEST_LIB_DIR=$$(PREPARE_DEST_LIB_DIR) +prepare-host-lib-$(1)-$(2)-$(3): $$(foreach dep,$$(RUST_DEPS_$(1)),prepare-host-lib-$$(dep)-$(2)-$(3))\ + $$(HLIB$(2)_H_$(3))/stamp.$(1) + $$(if $$(findstring $(2), $$(PREPARE_STAGE)),\ + $$(if $$(findstring $(3), $$(PREPARE_HOST)),\ + $$(call PREPARE_LIB,$$(call CFG_LIB_GLOB_$$(PREPARE_HOST),$(1))),),) +endef + +$(foreach lib,$(CRATES),\ + $(foreach stage,$(PREPARE_STAGES),\ + $(foreach host,$(CFG_HOST),\ + $(eval $(call DEF_PREPARE_HOST_LIB,$(lib),$(stage),$(host)))))) + +prepare-targets:\ + $(foreach host,$(CFG_HOST),\ + $(foreach target,$(CFG_TARGET),\ + $(foreach stage,$(PREPARE_STAGES),\ + prepare-target-$(target)-host-$(host)-$(stage)))) + +# $(1) is target +# $(2) is host +# $(3) is stage +define DEF_PREPARE_TARGET_N +# Rebind PREPARE_*_LIB_DIR to point to rustlib, then install the libs for the targets +prepare-target-$(1)-host-$(2)-$(3): PREPARE_WORKING_SOURCE_LIB_DIR=$$(PREPARE_SOURCE_LIB_DIR)/rustlib/$(1)/lib +prepare-target-$(1)-host-$(2)-$(3): PREPARE_WORKING_DEST_LIB_DIR=$$(PREPARE_DEST_LIB_DIR)/rustlib/$(1)/lib +prepare-target-$(1)-host-$(2)-$(3): \ + $$(foreach crate,$$(TARGET_CRATES), \ + $$(TLIB$(3)_T_$(1)_H_$(2))/stamp.$$(crate)) +# Only install if this host and target combo is being prepared + $$(if $$(findstring $(2), $$(PREPARE_HOST)),\ + $$(if $$(findstring $(1), $$(PREPARE_TARGETS)),\ + $$(if $$(findstring $(3), $$(PREPARE_STAGE)),\ + $$(call PREPARE_DIR,$$(PREPARE_WORKING_DEST_LIB_DIR))\ + $$(foreach crate,$$(TARGET_CRATES),\ + $$(call PREPARE_LIB,$$(call CFG_LIB_GLOB_$(1),$$(crate))))\ + $$(foreach crate,$$(TARGET_CRATES),\ + $$(call PREPARE_LIB,$$(call CFG_RLIB_GLOB,$$(crate))))\ + $$(call PREPARE_LIB,libmorestack.a) + $$(call PREPARE_LIB,libcompiler-rt.a),),),) +endef + +$(foreach host,$(CFG_HOST),\ + $(foreach target,$(CFG_TARGET), \ + $(foreach stage,$(PREPARE_STAGES),\ + $(eval $(call DEF_PREPARE_TARGET_N,$(target),$(host),$(stage))))))