49 lines
1.3 KiB
Makefile
49 lines
1.3 KiB
Makefile
# simple logging switch inspired by netch@'s advice:
|
|
# you can add plain $(LOG) to a rule recipe line to moderate it
|
|
# (logfile is automatically truncated during profile/init)
|
|
|
|
ifeq (,$(MKIMAGE_PROFILES))
|
|
$(error this makefile is designed to be included in toplevel one)
|
|
endif
|
|
|
|
# 1.3.22 fixes http://bugzilla.altlinux.org/26217
|
|
HSH_VER_OPTIMAL = 1.3.22
|
|
HSH_VERSION := $(shell hsh -V | sed -n 's/^.* version \([0-9.]\+\).*$$/\1/p')
|
|
|
|
ifeq (-,$(shell rpmvercmp $(HSH_VERSION) $(HSH_VER_OPTIMAL) | tr -d '[0-9]'))
|
|
$(info warning: hasher-$(HSH_VERSION) is suboptimal, consider upgrading)
|
|
endif
|
|
|
|
BUILDLOG ?= $(BUILDDIR)/$(BUILD_LOG)
|
|
|
|
# LOG holds a redirecting postprocessor
|
|
ifneq (,$(DEBUG))
|
|
# 1) makefile target; 2) also passed to script hooks
|
|
GLOBAL_DEBUG := debug
|
|
GLOBAL_VERBOSE ?= $(DEBUG)
|
|
ifeq (2,$(DEBUG))
|
|
SHELL += -x
|
|
endif
|
|
ifeq (1,$(STDOUT))
|
|
LOG = 2>&1 | tee -a $(BUILDLOG)
|
|
LOG_STDERR = $(LOG)
|
|
else
|
|
LOG = >>$(BUILDLOG) 2>&1
|
|
LOG_STDERR = 2> >(tee -a $(BUILDLOG) >&2) 1>>$(BUILDLOG)
|
|
endif
|
|
else
|
|
MAKE += -s
|
|
LOG = 2>>$(BUILDLOG) >/dev/null
|
|
LOG_STDERR = 2> >(tee -a $(BUILDLOG) >&2) 1>/dev/null
|
|
endif
|
|
|
|
ifeq (,$(filter-out $(DIRECT_TARGETS),$(MAKECMDGOALS)))
|
|
LOG = >/dev/null 2>&1
|
|
endif
|
|
|
|
# in build.mk, naive TIME gets expanded a bit too early (no need to export btw)
|
|
DATE = $(shell date +%Y%m%d)
|
|
TIME = `date +%H:%M:%S`
|
|
|
|
export BUILDLOG DATE GLOBAL_DEBUG GLOBAL_VERBOSE LOG MAKE SHELL
|