source: common/libs/func_wrt_Makefile@ 560bef1

2.4 ablfs-more legacy new_features trunk
Last change on this file since 560bef1 was f0a31de, checked in by Pierre Labastie <pierre@…>, 11 years ago

Add a sect2 template to lfs.xsl, so that it is possible to build
several packages on the same page

  • Property mode set to 100644
File size: 9.2 KB
Line 
1#!/bin/bash
2
3# $Id$
4
5#=== MAKEFILE HEADER ===
6
7#----------------------------------#
8wrt_Makefile_header() { #
9#----------------------------------#
10(
11 cat << EOF
12# This file is automatically generated by jhalfs
13# DO NOT EDIT THIS FILE MANUALLY
14#
15# Generated on `date "+%F %X %Z"`
16
17
18SHELL = /bin/bash
19
20SRC = /sources
21MOUNT_PT = $BUILDDIR
22PKG_LST = $PKG_LST
23LUSER = $LUSER
24LGROUP = $LGROUP
25LHOME = $LHOME
26SCRIPT_ROOT = $SCRIPT_ROOT
27
28BASEDIR = \$(MOUNT_PT)
29SRCSDIR = \$(BASEDIR)/sources
30CMDSDIR = \$(BASEDIR)/\$(SCRIPT_ROOT)/$PROGNAME-commands
31LOGDIR = \$(BASEDIR)/\$(SCRIPT_ROOT)/$LOGDIRBASE
32TESTLOGDIR = \$(BASEDIR)/\$(SCRIPT_ROOT)/$TESTLOGDIRBASE
33
34crCMDSDIR = /\$(SCRIPT_ROOT)/$PROGNAME-commands
35crLOGDIR = /\$(SCRIPT_ROOT)/$LOGDIRBASE
36crTESTLOGDIR = /\$(SCRIPT_ROOT)/$TESTLOGDIRBASE
37crFILELOGDIR = /\$(SCRIPT_ROOT)/$FILELOGDIRBASE
38
39SU_LUSER = su - \$(LUSER) -c
40LUSER_HOME = \$(LHOME)/\$(LUSER)
41PRT_DU = echo -e "\nKB: \`du -skx --exclude=\$(SCRIPT_ROOT) --exclude=lost+found \$(MOUNT_PT) \`\n"
42PRT_DU_CR = echo -e "\nKB: \`du -skx --exclude=\$(SCRIPT_ROOT) --exclude=lost+found / \`\n"
43
44ADD_REPORT = $REPORT
45ADD_CUSTOM_TOOLS = $CUSTOM_TOOLS
46ADD_BLFS_TOOLS = $BLFS_TOOL
47PKGMNGT = $PKGMNGT
48
49
50export PATH := \${PATH}:/usr/sbin
51
52include makefile-functions
53
54EOF
55) > $MKFILE
56}
57
58#=======================
59
60
61#==== PACKAGES NAMES ===
62
63#----------------------------------#
64get_package_tarball_name() { #
65#----------------------------------#
66 local script_name=`echo ${1} | sed -e 's@[0-9]\{1\}-@@'`
67
68 # The use of 'head' is necessary to limit the return value to the FIRST match..
69 # hopefully this will not cause problems.
70 #
71 case $script_name in
72 tcl) echo $(grep "^tcl" $JHALFSDIR/pkg_tarball_list | head -n1 )
73 ;;
74 iputils) echo $(grep "^iputils" $JHALFSDIR/pkg_tarball_list | head -n1 )
75 ;;
76 powerpc-utils) echo $(grep "^powerpc-utils" $JHALFSDIR/pkg_tarball_list | head -n1 )
77 ;;
78 uClibc)
79 if [[ "${PROGNAME}" = "clfs3" ]]; then
80 echo $(grep "^uClibc-" $JHALFSDIR/pkg_tarball_list | head -n1 )
81 else
82 echo $(grep "^$script_name-[[:digit:]]" $JHALFSDIR/pkg_tarball_list | head -n1 )
83 fi
84 ;;
85 linux-headers)
86 if [[ "${PROGNAME}" = "lfs" ]] || [[ "${PROGNAME}" = "hlfs" ]] || [[ "${PROGNAME}" = "clfs" ]]; then
87 # Uses kernel headers directly
88 echo $(grep "^linux-[[:digit:]]" $JHALFSDIR/pkg_tarball_list | head -n1 )
89 else
90 # CLFS{2,3} used to use massaged headers package
91 # echo $(grep "^linux-headers-[[:digit:]]" $JHALFSDIR/pkg_tarball_list | head -n1 )
92 echo $(grep "^linux-[[:digit:]]" $JHALFSDIR/pkg_tarball_list | head -n1 )
93 fi
94 ;;
95 expect) echo $(grep "^expect" $JHALFSDIR/pkg_tarball_list | head -n1 )
96 ;;
97 e2fsprogs-libs) echo $(grep "^e2fsprogs" $JHALFSDIR/pkg_tarball_list | head -n1 )
98 ;;
99 libcap) echo $(grep "^libcap" $JHALFSDIR/pkg_tarball_list | head -n1 )
100 ;;
101 util-linux-libs) echo $(grep "^util-linux" $JHALFSDIR/pkg_tarball_list | head -n1 )
102 ;;
103 xz-utils) echo $(grep "^xz" $JHALFSDIR/pkg_tarball_list | head -n1 )
104 ;;
105 sqlite) echo $(grep "^sqlite" $JHALFSDIR/pkg_tarball_list | head -n1 )
106 ;;
107 udev) echo $(grep "^systemd" $JHALFSDIR/pkg_tarball_list | head -n1 )
108 ;;
109 *) echo $(grep "^$script_name[_-][[:digit:]]" $JHALFSDIR/pkg_tarball_list | head -n1 )
110 ;;
111 esac
112
113}
114
115#=======================
116
117
118#==== TARGET HEADER ====
119
120#----------------------------------#
121LUSER_wrt_target() { # Create target and initialize log file
122#----------------------------------#
123 local i=$1
124 local PREV=$2
125(
126cat << EOF
127
128$i: $PREV
129 @\$(call echo_message, Building)
130${NO_PROGRESS} @export BASHBIN=\$(SHELL) && \$(SHELL) progress_bar.sh \$@ \$\$PPID &
131 @echo "\$(nl_)\`date\`\$(nl_)" >logs/\$@
132 @\$(PRT_DU) >>logs/\$@
133EOF
134) >> $MKFILE.tmp
135}
136
137#----------------------------------#
138CHROOT_wrt_target() { # Create target and initialize log file
139#----------------------------------#
140 local i=$1
141 local PREV=$2
142(
143cat << EOF
144
145$i: $PREV
146 @\$(call echo_message, Building)
147${NO_PROGRESS} @export BASHBIN=\$(SHELL) && \$(SHELL) progress_bar.sh \$@ \$\$PPID &
148 @echo "\$(nl_)\`date\`\$(nl_)" >logs/\$@
149 @\$(PRT_DU_CR) >>logs/\$@
150EOF
151) >> $MKFILE.tmp
152}
153
154#=======================
155
156
157#======== UNPACK =======
158
159#----------------------------------#
160LUSER_wrt_unpack() { # Unpack and set 'ROOT' var
161#----------------------------------#
162 local FILE=$1
163 local optSAVE_PREVIOUS=$2
164
165 if [[ "${optSAVE_PREVIOUS}" != "1" ]]; then
166(
167cat << EOF
168 @\$(call remove_existing_dirs,$FILE)
169EOF
170) >> $MKFILE.tmp
171 fi
172
173(
174cat << EOF
175 @\$(call unpack,$FILE)
176 @\$(call get_pkg_root_LUSER)
177EOF
178) >> $MKFILE.tmp
179}
180
181#----------------------------------#
182CHROOT_Unpack() { #
183#----------------------------------#
184 local FILE=$1
185 local optSAVE_PREVIOUS=$2
186
187 if [ "${optSAVE_PREVIOUS}" != "1" ]; then
188(
189cat << EOF
190 @\$(call remove_existing_dirs2,$FILE)
191EOF
192) >> $MKFILE.tmp
193 fi
194(
195cat << EOF
196 @\$(call unpack2,$FILE)
197 @\$(call get_pkg_root2)
198EOF
199) >> $MKFILE.tmp
200}
201
202#=======================
203
204
205#===== TESTS LOGS ======
206
207#----------------------------------#
208LUSER_wrt_test_log() { # Initialize testsuite log file
209#----------------------------------#
210 local TESTLOGFILE=$1
211(
212cat << EOF
213 @echo "export TEST_LOG=\$(TESTLOGDIR)/$TESTLOGFILE" >> envars && \\
214 echo "\$(nl_)\`date\`\$(nl_)" >\$(TESTLOGDIR)/\$@
215EOF
216) >> $MKFILE.tmp
217}
218
219#----------------------------------#
220CHROOT_wrt_test_log() { #
221#----------------------------------#
222 local TESTLOGFILE=$1
223(
224cat << EOF
225 @echo "export TEST_LOG=\$(crTESTLOGDIR)/$TESTLOGFILE" >> envars && \\
226 echo "\$(nl_)\`date\`\$(nl_)" >test-logs/\$@
227EOF
228) >> $MKFILE.tmp
229}
230
231#=======================
232
233
234#======== RUN AS =======
235
236#----------------------------------#
237wrt_RunAsRoot() { # Some scripts must be run as root..
238#----------------------------------#
239 local MOUNT_ENV
240 local file=$1
241
242 case ${PROGNAME} in
243 lfs ) MOUNT_ENV="LFS" ;;
244 clfs ) MOUNT_ENV="CLFS" ;;
245 clfs2 ) MOUNT_ENV="CLFS" ;;
246 clfs3 ) MOUNT_ENV="CLFS" ;;
247 hlfs ) MOUNT_ENV="HLFS" ;;
248 *) echo "undefined progname $PROGNAME"; exit 1 ;;
249 esac
250
251(
252cat << EOF
253 @export ${MOUNT_ENV}=\$(MOUNT_PT) && \\
254 ${PROGNAME}-commands/`dirname $file`/\$@ >>logs/\$@ 2>&1 && \\
255 \$(PRT_DU) >>logs/\$@
256EOF
257) >> $MKFILE.tmp
258}
259
260#----------------------------------#
261LUSER_wrt_RunAsUser() { # Calculate time with perl, footer to log file
262#----------------------------------#
263 local file=$1
264
265(
266cat << EOF
267 @source ~/.bashrc && \\
268 \$(CMDSDIR)/`dirname $file`/\$@ >> logs/\$@ 2>&1 && \\
269 \$(PRT_DU) >>logs/\$@
270EOF
271) >> $MKFILE.tmp
272}
273
274#----------------------------------#
275CHROOT_wrt_RunAsRoot() { #
276#----------------------------------#
277 local file=$1
278(
279cat << EOF
280 @source envars && \\
281 \$(crCMDSDIR)/`dirname $file`/\$@ >>logs/\$@ 2>&1 && \\
282 \$(PRT_DU_CR) >>logs/\$@
283EOF
284) >> $MKFILE.tmp
285
286}
287
288#=======================
289
290
291#====== COPY FSTAB =====
292
293#----------------------------------#
294LUSER_wrt_CopyFstab() { #
295#----------------------------------#
296(
297cat << EOF
298 @cp -v \$(MOUNT_PT)/sources/fstab \$(MOUNT_PT)/etc/fstab >>logs/\$@ 2>&1 && \\
299 \$(PRT_DU) >>logs/\$@
300EOF
301) >> $MKFILE.tmp
302}
303
304#----------------------------------#
305CHROOT_wrt_CopyFstab() { #
306#----------------------------------#
307(
308cat << EOF
309 @cp -v /sources/fstab /etc/fstab >>logs/\$@ 2>&1 && \\
310 \$(PRT_DU_CR) >>logs/\$@
311EOF
312) >> $MKFILE.tmp
313}
314
315#=======================
316
317
318#==== INSTALLED FILES LOGS ====
319
320#----------------------------------#
321LUSER_wrt_TouchTimestamp() { #
322#----------------------------------#
323(
324cat << EOF
325 @\$(call touch_timestamp_LUSER)
326EOF
327) >> $MKFILE.tmp
328}
329
330#----------------------------------#
331CHROOT_wrt_TouchTimestamp() { #
332#----------------------------------#
333(
334cat << EOF
335 @\$(call touch_timestamp)
336EOF
337) >> $MKFILE.tmp
338}
339
340#----------------------------------#
341LUSER_wrt_LogNewFiles() { #
342#----------------------------------#
343 local name=`echo ${1} | sed 's/[0-9]-//'`
344(
345cat << EOF
346 @\$(call log_new_files_LUSER,$name)
347EOF
348) >> $MKFILE.tmp
349}
350
351#----------------------------------#
352CHROOT_wrt_LogNewFiles() { #
353#----------------------------------#
354 local name=`echo ${1} | sed 's/[0-9]-//'`
355(
356cat << EOF
357 @\$(call log_new_files,$name)
358EOF
359) >> $MKFILE.tmp
360}
361
362#=======================
363
364
365#==== RM BUILD DIRS ====
366
367#----------------------------------#
368LUSER_RemoveBuildDirs() { #
369#----------------------------------#
370 local name=`echo ${1} | sed 's/[0-9]-//'`
371(
372cat << EOF
373 @\$(call remove_build_dirs,$name)
374EOF
375) >> $MKFILE.tmp
376}
377
378#----------------------------------#
379CHROOT_wrt_RemoveBuildDirs() { #
380#----------------------------------#
381 local name=`echo ${1} | sed 's/[0-9]-//'`
382(
383cat << EOF
384 @\$(call remove_build_dirs2,$name)
385EOF
386) >> $MKFILE.tmp
387}
388
389#=======================
390
391
392#======== TOUCH ========
393
394#----------------------------------#
395wrt_touch() { #
396#----------------------------------#
397(
398cat << EOF
399 @\$(call housekeeping)
400EOF
401) >> $MKFILE.tmp
402}
403
404#=======================
Note: See TracBrowser for help on using the repository browser.