2007-09-19 16:50:48 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# $Id$
|
|
|
|
|
|
|
|
#=== MAKEFILE HEADER ===
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
wrt_Makefile_header() { #
|
|
|
|
#----------------------------------#
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
# This file is automatically generated by jhalfs
|
|
|
|
# DO NOT EDIT THIS FILE MANUALLY
|
|
|
|
#
|
|
|
|
# Generated on `date "+%F %X %Z"`
|
|
|
|
|
|
|
|
|
|
|
|
SHELL = /bin/bash
|
|
|
|
|
|
|
|
SRC = /sources
|
|
|
|
MOUNT_PT = $BUILDDIR
|
|
|
|
PKG_LST = $PKG_LST
|
|
|
|
LUSER = $LUSER
|
|
|
|
LGROUP = $LGROUP
|
|
|
|
LHOME = $LHOME
|
|
|
|
SCRIPT_ROOT = $SCRIPT_ROOT
|
|
|
|
|
|
|
|
BASEDIR = \$(MOUNT_PT)
|
|
|
|
SRCSDIR = \$(BASEDIR)/sources
|
|
|
|
CMDSDIR = \$(BASEDIR)/\$(SCRIPT_ROOT)/$PROGNAME-commands
|
|
|
|
LOGDIR = \$(BASEDIR)/\$(SCRIPT_ROOT)/$LOGDIRBASE
|
|
|
|
TESTLOGDIR = \$(BASEDIR)/\$(SCRIPT_ROOT)/$TESTLOGDIRBASE
|
|
|
|
|
|
|
|
crCMDSDIR = /\$(SCRIPT_ROOT)/$PROGNAME-commands
|
|
|
|
crLOGDIR = /\$(SCRIPT_ROOT)/$LOGDIRBASE
|
|
|
|
crTESTLOGDIR = /\$(SCRIPT_ROOT)/$TESTLOGDIRBASE
|
|
|
|
crFILELOGDIR = /\$(SCRIPT_ROOT)/$FILELOGDIRBASE
|
|
|
|
|
|
|
|
SU_LUSER = su - \$(LUSER) -c
|
|
|
|
LUSER_HOME = \$(LHOME)/\$(LUSER)
|
|
|
|
|
|
|
|
ADD_REPORT = $REPORT
|
|
|
|
ADD_CUSTOM_TOOLS = $CUSTOM_TOOLS
|
|
|
|
ADD_BLFS_TOOLS = $BLFS_TOOL
|
|
|
|
|
|
|
|
|
|
|
|
export PATH := \${PATH}:/usr/sbin
|
|
|
|
|
|
|
|
include makefile-functions
|
|
|
|
|
|
|
|
EOF
|
|
|
|
) > $MKFILE
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|
|
|
|
|
|
|
|
|
|
|
|
#==== TARGET HEADER ====
|
|
|
|
|
|
|
|
#----------------------------------#
|
2007-09-25 19:12:36 +00:00
|
|
|
LUSER_wrt_target() { # Create target and initialize envars file
|
2007-09-19 16:50:48 +00:00
|
|
|
#----------------------------------#
|
|
|
|
local i=$1
|
|
|
|
local PREV=$2
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
|
|
|
|
$i: $PREV
|
|
|
|
@\$(call echo_message, Building)
|
|
|
|
@export BASHBIN=\$(SHELL) && \$(SHELL) progress_bar.sh \$@ \$\$PPID &
|
2007-09-25 19:12:36 +00:00
|
|
|
@rm -f envars && touch envars
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
2007-09-25 19:12:36 +00:00
|
|
|
CHROOT_wrt_target() { #
|
2007-09-19 16:50:48 +00:00
|
|
|
#----------------------------------#
|
|
|
|
local i=$1
|
|
|
|
local PREV=$2
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
|
|
|
|
$i: $PREV
|
|
|
|
@\$(call echo_message, Building)
|
|
|
|
@export BASHBIN=\$(SHELL) && \$(SHELL) progress_bar.sh \$@ \$\$PPID &
|
2007-09-25 19:12:36 +00:00
|
|
|
@rm -f envars && touch envars
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|
|
|
|
|
|
|
|
|
|
|
|
#===== TESTS LOGS ======
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
LUSER_wrt_test_log() { # Initialize testsuite log file
|
|
|
|
#----------------------------------#
|
|
|
|
local TESTLOGFILE=$1
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@echo "export TEST_LOG=\$(TESTLOGDIR)/$TESTLOGFILE" >> envars && \\
|
2007-09-25 19:12:36 +00:00
|
|
|
echo "\$(nl_)\`date\`\$(nl_)" > \$(TESTLOGDIR)/\$@
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
CHROOT_wrt_test_log() { #
|
|
|
|
#----------------------------------#
|
|
|
|
local TESTLOGFILE=$1
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@echo "export TEST_LOG=\$(crTESTLOGDIR)/$TESTLOGFILE" >> envars && \\
|
2007-09-25 19:12:36 +00:00
|
|
|
echo "\$(nl_)\`date\`\$(nl_)" > test-logs/\$@
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|
|
|
|
|
|
|
|
|
|
|
|
#======== RUN AS =======
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
wrt_RunAsRoot() { # Some scripts must be run as root..
|
|
|
|
#----------------------------------#
|
|
|
|
local MOUNT_ENV
|
|
|
|
local file=$1
|
|
|
|
|
|
|
|
case ${PROGNAME} in
|
|
|
|
lfs ) MOUNT_ENV="LFS" ;;
|
|
|
|
clfs ) MOUNT_ENV="CLFS" ;;
|
|
|
|
clfs2 ) MOUNT_ENV="CLFS" ;;
|
|
|
|
clfs3 ) MOUNT_ENV="CLFS" ;;
|
|
|
|
hlfs ) MOUNT_ENV="HLFS" ;;
|
|
|
|
*) echo "undefined progname $PROGNAME"; exit 1 ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
(
|
|
|
|
cat << EOF
|
2007-09-25 19:12:36 +00:00
|
|
|
@export ${MOUNT_ENV}=\$(MOUNT_PT) && ${PROGNAME}-commands/`dirname $file`/\$@ > logs/\$@ 2>&1
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
2007-09-25 19:12:36 +00:00
|
|
|
LUSER_wrt_RunAsUser() { #
|
2007-09-19 16:50:48 +00:00
|
|
|
#----------------------------------#
|
|
|
|
local file=$1
|
|
|
|
|
|
|
|
(
|
|
|
|
cat << EOF
|
2007-09-25 19:12:36 +00:00
|
|
|
@source ~/.bashrc && \$(CMDSDIR)/`dirname $file`/\$@ > logs/\$@ 2>&1
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
CHROOT_wrt_RunAsRoot() { #
|
|
|
|
#----------------------------------#
|
|
|
|
local file=$1
|
|
|
|
(
|
|
|
|
cat << EOF
|
2007-09-25 19:12:36 +00:00
|
|
|
@source envars && \$(crCMDSDIR)/`dirname $file`/\$@ > logs/\$@ 2>&1
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|
|
|
|
|
|
|
|
|
|
|
|
#====== COPY FSTAB =====
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
LUSER_wrt_CopyFstab() { #
|
|
|
|
#----------------------------------#
|
|
|
|
(
|
|
|
|
cat << EOF
|
2007-09-25 19:12:36 +00:00
|
|
|
@cp -v \$(MOUNT_PT)/sources/fstab \$(MOUNT_PT)/etc/fstab > logs/\$@ 2>&1
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
CHROOT_wrt_CopyFstab() { #
|
|
|
|
#----------------------------------#
|
|
|
|
(
|
|
|
|
cat << EOF
|
2007-09-25 19:12:36 +00:00
|
|
|
@cp -v /sources/fstab /etc/fstab > logs/\$@ 2>&1
|
2007-09-19 16:50:48 +00:00
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|
|
|
|
|
|
|
|
|
|
|
|
#==== INSTALLED FILES LOGS ====
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
LUSER_wrt_TouchTimestamp() { #
|
|
|
|
#----------------------------------#
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@\$(call touch_timestamp_LUSER)
|
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
CHROOT_wrt_TouchTimestamp() { #
|
|
|
|
#----------------------------------#
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@\$(call touch_timestamp)
|
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
LUSER_wrt_LogNewFiles() { #
|
|
|
|
#----------------------------------#
|
|
|
|
local name=$1
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@\$(call log_new_files_LUSER,$name)
|
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
CHROOT_wrt_LogNewFiles() { #
|
|
|
|
#----------------------------------#
|
|
|
|
local name=$1
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@\$(call log_new_files,$name)
|
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|
|
|
|
|
|
|
|
|
|
|
|
#======== TOUCH ========
|
|
|
|
|
|
|
|
#----------------------------------#
|
|
|
|
wrt_touch() { #
|
|
|
|
#----------------------------------#
|
|
|
|
(
|
|
|
|
cat << EOF
|
|
|
|
@\$(call housekeeping)
|
|
|
|
EOF
|
|
|
|
) >> $MKFILE.tmp
|
|
|
|
}
|
|
|
|
|
|
|
|
#=======================
|