[0170229] | 1 | #!/bin/bash
|
---|
[dd810ea] | 2 |
|
---|
| 3 | # $Id$
|
---|
| 4 |
|
---|
[0818ea6] | 5 | set -e
|
---|
[0170229] | 6 |
|
---|
| 7 |
|
---|
| 8 | no_empty_builddir() {
|
---|
| 9 | 'clear'
|
---|
| 10 | cat <<- -EOF-
|
---|
| 11 | ${DD_BORDER}
|
---|
| 12 |
|
---|
| 13 | ${tab_}${tab_}${BOLD}${RED}W A R N I N G${OFF}
|
---|
| 14 | Looks like the \$BUILDDIR directory contains subdirectories
|
---|
| 15 | from a previous HLFS build.
|
---|
| 16 |
|
---|
| 17 | Please format the partition mounted on \$BUILDDIR or set
|
---|
[60b56fd] | 18 | a different build directory before running jhalfs-X.
|
---|
[0170229] | 19 | ${OFF}
|
---|
| 20 | ${DD_BORDER}
|
---|
| 21 | -EOF-
|
---|
| 22 | exit
|
---|
| 23 | }
|
---|
| 24 |
|
---|
| 25 |
|
---|
[60b56fd] | 26 | HEADER="# This file is automatically generated by jhalfs-X
|
---|
[0170229] | 27 | # DO NOT EDIT THIS FILE MANUALLY
|
---|
| 28 | #
|
---|
| 29 | # Generated on `date \"+%F %X %Z\"`"
|
---|
| 30 |
|
---|
| 31 |
|
---|
| 32 |
|
---|
| 33 | #----------------------------------#
|
---|
[5359c48] | 34 | wrt_target() { # Create target and initialize log file
|
---|
[0170229] | 35 | #----------------------------------#
|
---|
| 36 | local i=$1
|
---|
| 37 | local PREV=$2
|
---|
[b414549] | 38 | case $i in
|
---|
| 39 | iteration* ) local LOGFILE=$this_script.log ;;
|
---|
| 40 | * ) local LOGFILE=$this_script ;;
|
---|
| 41 | esac
|
---|
[0170229] | 42 | (
|
---|
| 43 | cat << EOF
|
---|
| 44 |
|
---|
| 45 | $i: $PREV
|
---|
| 46 | @\$(call echo_message, Building)
|
---|
[460ea63] | 47 | @./progress_bar.sh \$@ &
|
---|
| 48 | @echo -e "\n\`date\`\n\nKB: \`du -skx --exclude=${SCRIPT_ROOT} \$(MOUNT_PT)\`\n" >logs/$LOGFILE
|
---|
[0170229] | 49 | EOF
|
---|
| 50 | ) >> $MKFILE.tmp
|
---|
| 51 | }
|
---|
| 52 |
|
---|
| 53 |
|
---|
[3b63c8c] | 54 | #----------------------------------#
|
---|
| 55 | wrt_target_boot() { # Create target and initialize log file
|
---|
| 56 | #----------------------------------#
|
---|
| 57 | local i=$1
|
---|
| 58 | local PREV=$2
|
---|
| 59 | case $i in
|
---|
| 60 | iteration* ) local LOGFILE=$this_script.log ;;
|
---|
| 61 | * ) local LOGFILE=$this_script ;;
|
---|
| 62 | esac
|
---|
| 63 | (
|
---|
| 64 | cat << EOF
|
---|
| 65 |
|
---|
| 66 | $i: $PREV
|
---|
| 67 | @\$(call echo_message, Building)
|
---|
| 68 | @./progress_bar.sh \$@ &
|
---|
| 69 | @echo -e "\n\`date\`\n\nKB: \`du -skx --exclude=${SCRIPT_ROOT}\`\n" >logs/$LOGFILE
|
---|
| 70 | EOF
|
---|
| 71 | ) >> $MKFILE.tmp
|
---|
| 72 | }
|
---|
| 73 |
|
---|
| 74 | #----------------------------#
|
---|
| 75 | get_package_tarball_name() { #
|
---|
| 76 | #----------------------------#
|
---|
| 77 | local script_name=$1
|
---|
| 78 |
|
---|
| 79 | # The use of 'head' is necessary to limit the return value to the FIRST match..
|
---|
| 80 | # hopefully this will not cause problems.
|
---|
| 81 | #
|
---|
| 82 | case $script_name in
|
---|
[9485eba] | 83 | tcl) echo $(grep "^tcl" $JHALFSDIR/pkg_tarball_list | head -n1 ) ;;
|
---|
| 84 | linux-headers) echo $(grep "^linux-headers.*.bz2" $JHALFSDIR/pkg_tarball_list | head -n1 ) ;;
|
---|
| 85 | *) echo $(grep "^$script_name-[[:digit:]]" $JHALFSDIR/pkg_tarball_list | head -n1 ) ;;
|
---|
[3b63c8c] | 86 | esac
|
---|
| 87 |
|
---|
| 88 | }
|
---|
| 89 |
|
---|
[398a037] | 90 |
|
---|
[460ea63] | 91 | #----------------------------------#
|
---|
[398a037] | 92 | wrt_test_log() { # Initialize testsuite log file
|
---|
[460ea63] | 93 | #----------------------------------#
|
---|
[398a037] | 94 | local TESTLOGFILE=$1
|
---|
[460ea63] | 95 | (
|
---|
[398a037] | 96 | cat << EOF
|
---|
| 97 | @echo "export TEST_LOG=$TESTLOGDIR/$TESTLOGFILE" >> envars && \\
|
---|
| 98 | su - \$(LUSER) -c "echo -e '\n\`date\`\n' >$TESTLOGDIR/$TESTLOGFILE"
|
---|
[460ea63] | 99 | EOF
|
---|
| 100 | ) >> $MKFILE.tmp
|
---|
| 101 | }
|
---|
| 102 |
|
---|
| 103 | #----------------------------------#
|
---|
[398a037] | 104 | wrt_test_log2() { #
|
---|
[460ea63] | 105 | #----------------------------------#
|
---|
[398a037] | 106 | local TESTLOGFILE=$1
|
---|
[460ea63] | 107 | (
|
---|
[398a037] | 108 | cat << EOF
|
---|
| 109 | @echo "export TEST_LOG=/$SCRIPT_ROOT/test-logs/$TESTLOGFILE" >> envars && \\
|
---|
| 110 | echo -e "\n\`date\`\n" >test-logs/$TESTLOGFILE
|
---|
| 111 | EOF
|
---|
| 112 | ) >> $MKFILE.tmp
|
---|
| 113 | }
|
---|
| 114 |
|
---|
| 115 | #----------------------------------#
|
---|
| 116 | wrt_target_vars() { # Target vars for hlfs (cross-build method)
|
---|
| 117 | #----------------------------------#
|
---|
| 118 | (
|
---|
| 119 | cat << EOF
|
---|
| 120 | @echo "export target=$(uname -m)-${TARGET}" >> envars && \\
|
---|
| 121 | echo "export ldso=/lib/${LOADER}" >> envars
|
---|
| 122 | EOF
|
---|
| 123 | ) >> $MKFILE.tmp
|
---|
| 124 |
|
---|
| 125 | }
|
---|
| 126 |
|
---|
| 127 |
|
---|
| 128 | #----------------------------------#
|
---|
| 129 | wrt_copy_fstab() { #
|
---|
| 130 | #----------------------------------#
|
---|
| 131 | local i=$1
|
---|
| 132 | (
|
---|
| 133 | cat << EOF
|
---|
| 134 | @cp -v $FSTAB \$(MOUNT_PT)/etc/fstab >>logs/$i 2>&1
|
---|
| 135 | EOF
|
---|
| 136 | ) >> $MKFILE.tmp
|
---|
| 137 | }
|
---|
| 138 |
|
---|
| 139 |
|
---|
| 140 | #----------------------------------#
|
---|
| 141 | wrt_copy_fstab2() { #
|
---|
| 142 | #----------------------------------#
|
---|
| 143 | local i=$1
|
---|
| 144 | (
|
---|
| 145 | cat << EOF
|
---|
| 146 | @cp -v /sources/fstab /etc/fstab >>logs/$i 2>&1
|
---|
[460ea63] | 147 | EOF
|
---|
| 148 | ) >> $MKFILE.tmp
|
---|
| 149 | }
|
---|
| 150 |
|
---|
| 151 |
|
---|
[398a037] | 152 | #----------------------------------#
|
---|
| 153 | wrt_report() { #
|
---|
| 154 | #----------------------------------#
|
---|
| 155 | (
|
---|
| 156 | cat << EOF
|
---|
[460ea63] | 157 |
|
---|
[398a037] | 158 | create-sbu_du-report: $PREV
|
---|
| 159 | @\$(call echo_message, Building)
|
---|
| 160 | @./create-sbu_du-report.sh logs $VERSION
|
---|
| 161 | @\$(call echo_report,$VERSION-SBU_DU-$(date --iso-8601).report)
|
---|
| 162 | @touch \$@
|
---|
| 163 | EOF
|
---|
| 164 | ) >> $MKFILE.tmp
|
---|
| 165 |
|
---|
| 166 | chapter789="$chapter789 create-sbu_du-report"
|
---|
| 167 | }
|
---|
| 168 |
|
---|
| 169 | unset wrt_unpack
|
---|
[0170229] | 170 | #----------------------------------#
|
---|
[60b56fd] | 171 | wrt_unpack() { # Unpack and set 'ROOT' var
|
---|
[0170229] | 172 | #----------------------------------#
|
---|
| 173 | local FILE=$1
|
---|
[460ea63] | 174 | local optSAVE_PREVIOUS=$2
|
---|
| 175 |
|
---|
[398a037] | 176 | if [[ "${optSAVE_PREVIOUS}" != "1" ]]; then
|
---|
| 177 | (
|
---|
| 178 | cat << EOF
|
---|
| 179 | @\$(call remove_existing_dirs,$FILE)
|
---|
| 180 | EOF
|
---|
| 181 | ) >> $MKFILE.tmp
|
---|
[460ea63] | 182 | fi
|
---|
[398a037] | 183 |
|
---|
[0170229] | 184 | (
|
---|
| 185 | cat << EOF
|
---|
| 186 | @\$(call unpack,$FILE)
|
---|
[398a037] | 187 | @\$(call get_pkg_root)
|
---|
[3b63c8c] | 188 | EOF
|
---|
| 189 | ) >> $MKFILE.tmp
|
---|
| 190 |
|
---|
[398a037] | 191 | }
|
---|
[3b63c8c] | 192 |
|
---|
[398a037] | 193 | unset wrt_unpack2
|
---|
[0170229] | 194 | #----------------------------------#
|
---|
| 195 | wrt_unpack2() { #
|
---|
| 196 | #----------------------------------#
|
---|
| 197 | local FILE=$1
|
---|
[460ea63] | 198 | local optSAVE_PREVIOUS=$2
|
---|
| 199 |
|
---|
| 200 | if [ "${optSAVE_PREVIOUS}" != "1" ]; then
|
---|
[398a037] | 201 | (
|
---|
| 202 | cat << EOF
|
---|
| 203 | @\$(call remove_existing_dirs,$FILE)
|
---|
| 204 | EOF
|
---|
| 205 | ) >> $MKFILE.tmp
|
---|
[460ea63] | 206 | fi
|
---|
[0170229] | 207 | (
|
---|
| 208 | cat << EOF
|
---|
| 209 | @\$(call unpack2,$FILE)
|
---|
[398a037] | 210 | @\$(call get_pkg_root,nouser)
|
---|
[0170229] | 211 | EOF
|
---|
| 212 | ) >> $MKFILE.tmp
|
---|
| 213 | }
|
---|
| 214 |
|
---|
[65d83a6] | 215 | #----------------------------------#
|
---|
| 216 | wrt_unpack3() { #
|
---|
| 217 | #----------------------------------#
|
---|
[0170229] | 218 | local FILE=$1
|
---|
[460ea63] | 219 | local optSAVE_PREVIOUS=$2
|
---|
| 220 |
|
---|
| 221 | if [ "${optSAVE_PREVIOUS}" != "1" ]; then
|
---|
[398a037] | 222 | (
|
---|
| 223 | cat << EOF
|
---|
| 224 | @\$(call remove_existing_dirs2,$FILE)
|
---|
| 225 | EOF
|
---|
| 226 | ) >> $MKFILE.tmp
|
---|
[460ea63] | 227 | fi
|
---|
[0170229] | 228 | (
|
---|
| 229 | cat << EOF
|
---|
[c3c4e1d] | 230 | @\$(call unpack3,$FILE)
|
---|
[398a037] | 231 | @\$(call get_pkg_root2)
|
---|
[0170229] | 232 | EOF
|
---|
| 233 | ) >> $MKFILE.tmp
|
---|
| 234 | }
|
---|
| 235 |
|
---|
[398a037] | 236 |
|
---|
| 237 | unset wrt_remove_build_dirs
|
---|
[e35e794] | 238 | #----------------------------------#
|
---|
[398a037] | 239 | wrt_remove_build_dirs() { #
|
---|
[e35e794] | 240 | #----------------------------------#
|
---|
[398a037] | 241 | local name=$1
|
---|
[e35e794] | 242 | (
|
---|
[398a037] | 243 | cat << EOF
|
---|
| 244 | @\$(call remove_build_dirs,$name)
|
---|
[e35e794] | 245 | EOF
|
---|
| 246 | ) >> $MKFILE.tmp
|
---|
| 247 | }
|
---|
| 248 |
|
---|
| 249 | #----------------------------------#
|
---|
[398a037] | 250 | wrt_remove_build_dirs2() { #
|
---|
[e35e794] | 251 | #----------------------------------#
|
---|
[398a037] | 252 | local name=$1
|
---|
[e35e794] | 253 | (
|
---|
[398a037] | 254 | cat << EOF
|
---|
| 255 | @\$(call remove_build_dirs2,$name)
|
---|
[e35e794] | 256 | EOF
|
---|
| 257 | ) >> $MKFILE.tmp
|
---|
| 258 | }
|
---|
| 259 |
|
---|
[398a037] | 260 |
|
---|
| 261 |
|
---|
| 262 | unset wrt_touch
|
---|
[0170229] | 263 | #----------------------------------#
|
---|
[398a037] | 264 | wrt_touch() { #
|
---|
[0170229] | 265 | #----------------------------------#
|
---|
| 266 | (
|
---|
[398a037] | 267 | cat << EOF
|
---|
| 268 | @\$(call housekeeping)
|
---|
[0170229] | 269 | EOF
|
---|
| 270 | ) >> $MKFILE.tmp
|
---|
| 271 | }
|
---|
| 272 |
|
---|
[398a037] | 273 | unset wrt_RunAsUser
|
---|
[0170229] | 274 | #----------------------------------#
|
---|
[9485eba] | 275 | wrt_RunAsUser() { # Execute script inside time { }, footer to log file
|
---|
[0170229] | 276 | #----------------------------------#
|
---|
| 277 | local this_script=$1
|
---|
| 278 | local file=$2
|
---|
[398a037] | 279 |
|
---|
[0170229] | 280 | (
|
---|
| 281 | cat << EOF
|
---|
[398a037] | 282 | @( time { \$(SU_LUSER) "source \$(LUSER_HOME)/.bashrc && \$(CMDSDIR)/`dirname $file`/\$@" >> logs/\$@ 2>&1; } ) 2>> logs/\$@ && \\
|
---|
| 283 | \$(PRT_DU) >> logs/\$@
|
---|
[0170229] | 284 | EOF
|
---|
| 285 | ) >> $MKFILE.tmp
|
---|
| 286 | }
|
---|
| 287 |
|
---|
| 288 |
|
---|
| 289 | #----------------------------------#
|
---|
[9485eba] | 290 | wrt_RunAsRoot() { # Some scripts must be run as root..
|
---|
[0170229] | 291 | #----------------------------------#
|
---|
[9485eba] | 292 | local ENV_MOUNT
|
---|
[0170229] | 293 | local this_script=$1
|
---|
| 294 | local file=$2
|
---|
[3b63c8c] | 295 |
|
---|
[9485eba] | 296 | case ${PROGNAME} in
|
---|
| 297 | lfs ) MOUNT_ENV="LFS" ;;
|
---|
| 298 | blfs ) MOUNT_ENV="BLFS" ;;
|
---|
| 299 | clfs ) MOUNT_ENV="CLFS" ;;
|
---|
| 300 | clfs2 ) MOUNT_ENV="CLFS" ;;
|
---|
| 301 | hlfs ) MOUNT_ENV="HLFS" ;;
|
---|
| 302 | *) echo "undefined progname $PROGNAME"; exit 1
|
---|
| 303 | esac
|
---|
[0818ea6] | 304 |
|
---|
[3b63c8c] | 305 | (
|
---|
| 306 | cat << EOF
|
---|
[398a037] | 307 | @( time { export ${MOUNT_ENV}=\$(MOUNT_PT) && ${PROGNAME}-commands/`dirname $file`/\$@ >>logs/\$@ 2>&1 ; } ) 2>>logs/\$@ && \\
|
---|
| 308 | \$(PRT_DU_CR) >>logs/\$@
|
---|
[3b63c8c] | 309 | EOF
|
---|
| 310 | ) >> $MKFILE.tmp
|
---|
| 311 | }
|
---|
| 312 |
|
---|
[65d83a6] | 313 | #----------------------------------#
|
---|
| 314 | wrt_run_as_root2() { #
|
---|
| 315 | #----------------------------------#
|
---|
[0170229] | 316 | local this_script=$1
|
---|
| 317 | local file=$2
|
---|
| 318 | (
|
---|
| 319 | cat << EOF
|
---|
[398a037] | 320 | @( time { source envars && ${PROGNAME}-commands/`dirname $file`/\$@ >>logs/\$@ 2>&1 ; } ) 2>>logs/\$@ && \\
|
---|
| 321 | echo -e "\nKB: \`du -skx --exclude=${SCRIPT_ROOT} \`\n" >>logs/\$@
|
---|
[0170229] | 322 | EOF
|
---|
| 323 | ) >> $MKFILE.tmp
|
---|
| 324 | }
|
---|
| 325 |
|
---|
| 326 |
|
---|
[398a037] | 327 | unset wrt_run_as_chroot1
|
---|
[0170229] | 328 | #----------------------------------#
|
---|
| 329 | wrt_run_as_chroot1() { #
|
---|
| 330 | #----------------------------------#
|
---|
| 331 | local this_script=$1
|
---|
| 332 | local file=$2
|
---|
| 333 | (
|
---|
[398a037] | 334 | cat << EOF
|
---|
[dfdf5ee] | 335 | @( time { \$(CHROOT1) 'cd \$(SCRIPT_ROOT) && source envars && \$(crCMDSDIR)/$file >>logs/\$@ 2>&1' ; } ) 2>>logs/\$@ && \\
|
---|
[398a037] | 336 | \$(PRT_DU_CR) >> logs/\$@
|
---|
[0170229] | 337 | EOF
|
---|
| 338 | ) >> $MKFILE.tmp
|
---|
| 339 | }
|
---|
| 340 |
|
---|
[398a037] | 341 | unset wrt_run_as_chroot2
|
---|
[0170229] | 342 | #----------------------------------#
|
---|
| 343 | wrt_run_as_chroot2() { #
|
---|
| 344 | #----------------------------------#
|
---|
| 345 | local this_script=$1
|
---|
| 346 | local file=$2
|
---|
| 347 | (
|
---|
| 348 | cat << EOF
|
---|
[74faad1] | 349 | @( time { \$(CHROOT2) 'cd \$(SCRIPT_ROOT) && source envars && \$(crCMDSDIR)/`dirname $file`/\$@ >>logs/\$@ 2>&1' ; } ) 2>>logs/\$@ && \\
|
---|
[398a037] | 350 | \$(PRT_DU_CR) >> logs/\$@
|
---|
[0170229] | 351 | EOF
|
---|
| 352 | ) >> $MKFILE.tmp
|
---|
| 353 | }
|
---|
| 354 |
|
---|
[398a037] | 355 | unset wrt_target
|
---|
[0170229] | 356 | #----------------------------------#
|
---|
[398a037] | 357 | wrt_target() { # Create target and initialize log file
|
---|
[0170229] | 358 | #----------------------------------#
|
---|
| 359 | local i=$1
|
---|
[398a037] | 360 | local PREV=$2
|
---|
| 361 | case $i in
|
---|
| 362 | iteration* ) local LOGFILE="\$@.log" ;;
|
---|
| 363 | * ) local LOGFILE="\$@" ;;
|
---|
| 364 | esac
|
---|
[5359c48] | 365 | (
|
---|
| 366 | cat << EOF
|
---|
[0170229] | 367 |
|
---|
[398a037] | 368 | $i: $PREV
|
---|
| 369 | @\$(call echo_message, Building)
|
---|
| 370 | @./progress_bar.sh \$@ &
|
---|
| 371 | @echo -e "\n\`date\`\n\nKB: \`du -skx --exclude=${SCRIPT_ROOT} \$(MOUNT_PT)\`\n" >logs/$LOGFILE
|
---|
[9199a13] | 372 | EOF
|
---|
| 373 | ) >> $MKFILE.tmp
|
---|
| 374 | }
|
---|
| 375 |
|
---|
[9e4b9a1] | 376 | #----------------------------------#
|
---|
[398a037] | 377 | wrt_target_boot() { # Create target and initialize log file
|
---|
[9e4b9a1] | 378 | #----------------------------------#
|
---|
[398a037] | 379 | local i=$1
|
---|
| 380 | local PREV=$2
|
---|
| 381 | case $i in
|
---|
| 382 | iteration* ) local LOGFILE="\$@.log" ;;
|
---|
| 383 | * ) local LOGFILE="\$@" ;;
|
---|
| 384 | esac
|
---|
[9e4b9a1] | 385 | (
|
---|
| 386 | cat << EOF
|
---|
| 387 |
|
---|
[398a037] | 388 | $i: $PREV
|
---|
[9e4b9a1] | 389 | @\$(call echo_message, Building)
|
---|
[398a037] | 390 | @./progress_bar.sh \$@ &
|
---|
| 391 | @echo -e "\n\`date\`\n\nKB: \`du -skx --exclude=${SCRIPT_ROOT}\`\n" >logs/$LOGFILE
|
---|
[9e4b9a1] | 392 | EOF
|
---|
| 393 | ) >> $MKFILE.tmp
|
---|
| 394 | }
|
---|
| 395 |
|
---|
| 396 |
|
---|
[398a037] | 397 |
|
---|
[0170229] | 398 | #----------------------------#
|
---|
[65d83a6] | 399 | run_make() { #
|
---|
[0170229] | 400 | #----------------------------#
|
---|
| 401 | # Test if make must be run.
|
---|
[47fddc8] | 402 | if [ "$RUNMAKE" = "y" ] ; then
|
---|
[0170229] | 403 | # Test to make sure we're running the build as root
|
---|
| 404 | if [ "$UID" != "0" ] ; then
|
---|
[60b56fd] | 405 | echo "You must be logged in as root to successfully build the system."
|
---|
[0170229] | 406 | exit 1
|
---|
| 407 | fi
|
---|
| 408 | # Build the system
|
---|
| 409 | if [ -e $MKFILE ] ; then
|
---|
[60b56fd] | 410 | echo -ne "Building the system...\n"
|
---|
[54b4b32] | 411 | cd $JHALFSDIR && make
|
---|
[0170229] | 412 | echo -ne "done\n"
|
---|
| 413 | fi
|
---|
| 414 | fi
|
---|
| 415 | }
|
---|
| 416 |
|
---|
| 417 |
|
---|
| 418 | #----------------------------#
|
---|
[65d83a6] | 419 | clean_builddir() { #
|
---|
[0170229] | 420 | #----------------------------#
|
---|
| 421 | # Test if the clean must be done.
|
---|
[47fddc8] | 422 | if [ "${CLEAN}" = "y" ]; then
|
---|
[0170229] | 423 | # Test to make sure we're running the clean as root
|
---|
| 424 | if [ "$UID" != "0" ] ; then
|
---|
| 425 | echo "You must be logged in as root to clean the build directory."
|
---|
| 426 | exit 1
|
---|
| 427 | fi
|
---|
| 428 | # Test to make sure that the build directory was populated by jhalfs
|
---|
| 429 | if [ ! -d $JHALFSDIR ] || [ ! -d $BUILDDIR/sources ] ; then
|
---|
[60b56fd] | 430 | echo "Looks like $BUILDDIR was not populated by a previous jhalfs-X run."
|
---|
[0170229] | 431 | exit 1
|
---|
| 432 | else
|
---|
| 433 | # Clean the build directory
|
---|
| 434 | echo -ne "Cleaning $BUILDDIR...\n"
|
---|
[3465451] | 435 | rm -rf $BUILDDIR/{bin,boot,dev,etc,home,lib,media,mnt,opt,proc,root,sbin,srv,sys,tmp,tools,cross-tools,usr,var}
|
---|
[0170229] | 436 | echo -ne "Cleaning $JHALFSDIR...\n"
|
---|
[3b63c8c] | 437 | rm -rf $JHALFSDIR/{0*,1*,envars,sources-dir,*commands,*logs,Makefile,*.xsl,makefile-functions,pkg_tarball_list,*.config,*.sh}
|
---|
[0170229] | 438 | echo -ne "Cleaning remainig extracted sources in $BUILDDIR/sources...\n"
|
---|
| 439 | rm -rf `find $BUILDDIR/sources/* -maxdepth 0 -type d`
|
---|
| 440 | echo -ne "done\n"
|
---|
| 441 | fi
|
---|
| 442 | fi
|
---|
| 443 | }
|
---|
| 444 |
|
---|
| 445 | #----------------------------#
|
---|
[65d83a6] | 446 | get_book() { #
|
---|
[0170229] | 447 | #----------------------------#
|
---|
| 448 | cd $JHALFSDIR
|
---|
| 449 |
|
---|
[2b0f8a5] | 450 | if [ -z $WORKING_COPY ] ; then
|
---|
[0170229] | 451 | # Check for Subversion instead of just letting the script hit 'svn' and fail.
|
---|
| 452 | test `type -p svn` || eval "echo \"This feature requires Subversion.\"
|
---|
| 453 | exit 1"
|
---|
| 454 | echo -n "Downloading the $PROGNAME document, $LFSVRS version... "
|
---|
| 455 |
|
---|
| 456 | case $PROGNAME in
|
---|
| 457 | lfs) svn_root="LFS" ;;
|
---|
| 458 | hlfs) svn_root="HLFS" ;;
|
---|
| 459 | clfs) svn_root="cross-lfs" ;;
|
---|
[3b63c8c] | 460 | clfs2) svn_root="cross-lfs" ;;
|
---|
[0170229] | 461 | *) echo "BOOK not defined in function <get_book>"
|
---|
| 462 | exit 1 ;;
|
---|
| 463 | esac
|
---|
[60b56fd] | 464 | # Grab a fresh book if it's missing, otherwise, update it from the
|
---|
[0170229] | 465 | # repo. If we've already extracted the commands, move on to getting the
|
---|
| 466 | # sources.
|
---|
| 467 | if [ -d ${PROGNAME}-$LFSVRS ] ; then
|
---|
| 468 | cd ${PROGNAME}-$LFSVRS
|
---|
[3b63c8c] | 469 | if LC_ALL=C svn up | grep -q At && \
|
---|
| 470 | test -d $JHALFSDIR/${PROGNAME}-commands && \
|
---|
| 471 | test -f $JHALFSDIR/pkg_tarball_list ; then
|
---|
[0170229] | 472 | # Set the canonical book version
|
---|
[3b63c8c] | 473 | echo -ne "done\n"
|
---|
[0170229] | 474 | cd $JHALFSDIR
|
---|
[3b63c8c] | 475 | case $PROGNAME in
|
---|
| 476 | clfs | clfs2)
|
---|
| 477 | VERSION=$(xmllint --noent $BOOK/prologue/$ARCH/bookinfo.xml 2>/dev/null | grep subtitle | sed -e 's/^.*ion //' -e 's/<\/.*//') ;;
|
---|
| 478 | *)
|
---|
| 479 | VERSION=$(xmllint --noent $BOOK/prologue/bookinfo.xml 2>/dev/null | grep subtitle | sed -e 's/^.*ion //' -e 's/<\/.*//') ;;
|
---|
| 480 | esac
|
---|
[0170229] | 481 | get_sources
|
---|
| 482 | else
|
---|
| 483 | echo -ne "done\n"
|
---|
| 484 | extract_commands
|
---|
| 485 | fi
|
---|
| 486 | else
|
---|
[3b63c8c] | 487 | svn co $SVN/${svn_root}/${TREE} ${PROGNAME}-$LFSVRS >>$LOGDIR/$LOG 2>&1
|
---|
[0170229] | 488 | echo -ne "done\n"
|
---|
| 489 | extract_commands
|
---|
| 490 | fi
|
---|
[3b63c8c] | 491 |
|
---|
[0170229] | 492 | else
|
---|
| 493 | echo -ne "Using $BOOK as book's sources ...\n"
|
---|
| 494 | extract_commands
|
---|
| 495 | fi
|
---|
[3b63c8c] | 496 | echo -ne " Document version ${L_arrow}${BOLD}${VERSION}${R_arrow}\n"
|
---|
[0170229] | 497 | }
|
---|
| 498 |
|
---|
| 499 | #----------------------------#
|
---|
| 500 | extract_commands() { #
|
---|
| 501 | #----------------------------#
|
---|
[9e1915a] | 502 |
|
---|
[0170229] | 503 | # Check for libxslt instead of just letting the script hit 'xsltproc' and fail.
|
---|
| 504 | test `type -p xsltproc` || eval "echo \"This feature requires libxslt.\"
|
---|
| 505 | exit 1"
|
---|
| 506 |
|
---|
| 507 | cd $JHALFSDIR
|
---|
[3b63c8c] | 508 | case $PROGNAME in
|
---|
| 509 | clfs | clfs2 )
|
---|
| 510 | VERSION=$(xmllint --noent $BOOK/prologue/$ARCH/bookinfo.xml 2>/dev/null | grep subtitle | sed -e 's/^.*ion //' -e 's/<\/.*//') ;;
|
---|
| 511 | *)
|
---|
| 512 | VERSION=$(xmllint --noent $BOOK/prologue/bookinfo.xml 2>/dev/null | grep subtitle | sed -e 's/^.*ion //' -e 's/<\/.*//') ;;
|
---|
| 513 | esac
|
---|
[0170229] | 514 |
|
---|
| 515 | # Start clean
|
---|
[3e3e28b] | 516 | if [ -d ${PROGNAME}-commands ]; then
|
---|
| 517 | rm -rf ${PROGNAME}-commands
|
---|
| 518 | mkdir -v ${PROGNAME}-commands
|
---|
[0170229] | 519 | fi
|
---|
[bef0a98] | 520 | echo -n "Extracting commands for"
|
---|
[0170229] | 521 |
|
---|
| 522 | # Dump the commands in shell script form from the HLFS book.
|
---|
| 523 | case ${PROGNAME} in
|
---|
| 524 | clfs)
|
---|
[9c90294] | 525 | echo -n " ${L_arrow}${BOLD}$ARCH${R_arrow} target architecture"
|
---|
[e676ffa] | 526 | xsltproc --nonet \
|
---|
| 527 | --xinclude \
|
---|
| 528 | --stringparam method $METHOD \
|
---|
| 529 | --stringparam testsuite $TEST \
|
---|
[056486c] | 530 | --stringparam bomb-testsuite $BOMB_TEST \
|
---|
[e676ffa] | 531 | --stringparam vim-lang $VIMLANG \
|
---|
| 532 | --stringparam timezone $TIMEZONE \
|
---|
| 533 | --stringparam page $PAGE \
|
---|
| 534 | --stringparam lang $LANG \
|
---|
[47fddc8] | 535 | --stringparam keymap $KEYMAP \
|
---|
[a9490ab] | 536 | -o ./${PROGNAME}-commands/ $XSL $BOOK/$ARCH-index.xml >>$LOGDIR/$LOG 2>&1
|
---|
[0170229] | 537 | ;;
|
---|
[3b63c8c] | 538 |
|
---|
| 539 | clfs2)
|
---|
| 540 | echo -n " ${L_arrow}${BOLD}$ARCH${R_arrow} target architecture"
|
---|
| 541 | xsltproc --nonet \
|
---|
| 542 | --xinclude \
|
---|
| 543 | --stringparam vim-lang $VIMLANG \
|
---|
| 544 | --stringparam timezone $TIMEZONE \
|
---|
| 545 | --stringparam page $PAGE \
|
---|
| 546 | --stringparam lang $LANG \
|
---|
[47fddc8] | 547 | --stringparam keymap $KEYMAP \
|
---|
[3b63c8c] | 548 | -o ./${PROGNAME}-commands/ $XSL $BOOK/$ARCH-index.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 549 | ;;
|
---|
[0170229] | 550 | hlfs)
|
---|
[60b56fd] | 551 | echo -n " ${L_arrow}${BOLD}$MODEL${R_arrow} HLFS libc implementation"
|
---|
[ad71d98] | 552 | xsltproc --nonet \
|
---|
| 553 | --xinclude \
|
---|
| 554 | --stringparam model $MODEL \
|
---|
| 555 | --stringparam testsuite $TEST \
|
---|
[056486c] | 556 | --stringparam bomb-testsuite $BOMB_TEST \
|
---|
[ad71d98] | 557 | --stringparam timezone $TIMEZONE \
|
---|
| 558 | --stringparam page $PAGE \
|
---|
[d87b293] | 559 | --stringparam lang $LANG \
|
---|
| 560 | --stringparam lc_all $LC_ALL \
|
---|
[47fddc8] | 561 | --stringparam keymap $KEYMAP \
|
---|
[ad71d98] | 562 | --stringparam grsecurity_host $GRSECURITY_HOST \
|
---|
| 563 | -o ./${PROGNAME}-commands/ $XSL $BOOK/index.xml >>$LOGDIR/$LOG 2>&1
|
---|
[0170229] | 564 | ;;
|
---|
| 565 | lfs)
|
---|
[9c90294] | 566 | echo -n " ${L_arrow}${BOLD}LFS${R_arrow} build"
|
---|
[0170229] | 567 | xsltproc --nonet \
|
---|
| 568 | --xinclude \
|
---|
| 569 | --stringparam testsuite $TEST \
|
---|
[056486c] | 570 | --stringparam bomb-testsuite $BOMB_TEST \
|
---|
[0170229] | 571 | --stringparam vim-lang $VIMLANG \
|
---|
[ad71d98] | 572 | --stringparam timezone $TIMEZONE \
|
---|
| 573 | --stringparam page $PAGE \
|
---|
[d87b293] | 574 | --stringparam lang $LANG \
|
---|
[0170229] | 575 | -o ./${PROGNAME}-commands/ $XSL $BOOK/index.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 576 | ;;
|
---|
[3e7af38] | 577 | *) exit 1 ;;
|
---|
[0170229] | 578 | esac
|
---|
[dd810ea] | 579 |
|
---|
[3c5ca23] | 580 | [[ "${BLFS_TOOL}" = "y" ]] && copy_blfs_deps_scripts
|
---|
| 581 |
|
---|
[bef0a98] | 582 | echo " ...OK"
|
---|
[0170229] | 583 |
|
---|
| 584 | # Make the scripts executable.
|
---|
| 585 | chmod -R +x $JHALFSDIR/${PROGNAME}-commands
|
---|
| 586 |
|
---|
[3e7af38] | 587 | # Create the packages file. We need it for proper Makefile creation
|
---|
[3b63c8c] | 588 | create_package_list
|
---|
[0170229] | 589 |
|
---|
| 590 | # Done. Moving on...
|
---|
| 591 | get_sources
|
---|
| 592 | }
|
---|
| 593 |
|
---|
[3b63c8c] | 594 | #----------------------------#
|
---|
| 595 | create_package_list() { #
|
---|
| 596 | #----------------------------#
|
---|
| 597 |
|
---|
| 598 | # Create the packages file. We need it for proper Makefile creation
|
---|
| 599 | rm -f pkg_tarball_list
|
---|
| 600 | echo -n "Creating <${PROGNAME}> list of tarball names for $BOOK $ARCH"
|
---|
| 601 | case ${PROGNAME} in
|
---|
| 602 | clfs | clfs2)
|
---|
| 603 | xsltproc --nonet --xinclude -o pkg_tarball_list packages.xsl \
|
---|
| 604 | $BOOK/materials/${ARCH}-chapter.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 605 | ;;
|
---|
| 606 | hlfs)
|
---|
| 607 | xsltproc --nonet --xinclude -o pkg_tarball_list packages.xsl \
|
---|
| 608 | $BOOK/chapter04/chapter04.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 609 | ;;
|
---|
| 610 | lfs)
|
---|
| 611 | xsltproc --nonet --xinclude -o pkg_tarball_list packages.xsl \
|
---|
| 612 | $BOOK/chapter03/chapter03.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 613 | ;;
|
---|
| 614 | esac
|
---|
[f67691e] | 615 |
|
---|
| 616 | if [[ "${BLFS_TOOL}" = "y" ]] ; then
|
---|
| 617 | (
|
---|
| 618 | cat << EOF
|
---|
[c03e5d0] | 619 | $LIBXML_PKG
|
---|
| 620 | $LIBXSLT_PKG
|
---|
| 621 | $DBXSL_PKG
|
---|
| 622 | $LINKS_PKG
|
---|
| 623 | $SUDO_PKG
|
---|
| 624 | $WGET_PKG
|
---|
| 625 | $SVN_PKG
|
---|
| 626 | $GPM_PKG
|
---|
[f67691e] | 627 | EOF
|
---|
| 628 | ) >> pkg_tarball_list
|
---|
| 629 | fi
|
---|
| 630 |
|
---|
[3b63c8c] | 631 | echo " ...OK"
|
---|
| 632 |
|
---|
| 633 | }
|
---|
| 634 |
|
---|
| 635 |
|
---|
[0170229] | 636 | #----------------------------#
|
---|
[3e7af38] | 637 | get_sources() { # Download file, write name to MISSING_FILES.DMP if an error
|
---|
[0170229] | 638 | #----------------------------#
|
---|
[3e7af38] | 639 | local saveIFS=$IFS
|
---|
[7a100d96] | 640 | local IFS line URL1 URL2 FILE BOOKMD5 MD5 HAVEMD5 fromARCHIVE
|
---|
[65d83a6] | 641 |
|
---|
| 642 | # Test if the packages must be downloaded
|
---|
[47fddc8] | 643 | [ ! "$GETPKG" = "y" ] && return
|
---|
[65d83a6] | 644 |
|
---|
| 645 | gs_wrt_message(){
|
---|
| 646 | echo "${RED}$1${OFF}"
|
---|
| 647 | echo "$1" >> MISSING_FILES.DMP
|
---|
| 648 | }
|
---|
| 649 | # Housekeeping
|
---|
| 650 | [[ ! -d $BUILDDIR/sources ]] && mkdir $BUILDDIR/sources
|
---|
| 651 | cd $BUILDDIR/sources
|
---|
| 652 | [[ -f MD5SUMS ]] && rm MD5SUMS
|
---|
| 653 | [[ -f MISSING_FILES.DMP ]] && rm MISSING_FILES.DMP
|
---|
| 654 | [[ -f urls.lst ]] && rm urls.lst
|
---|
[4aede02] | 655 |
|
---|
[3e7af38] | 656 | # Generate URLs file
|
---|
[65d83a6] | 657 | create_urls
|
---|
[3e7af38] | 658 |
|
---|
[65d83a6] | 659 | IFS=$'\x0A' # Modify the 'internal field separator' to break on 'LF' only
|
---|
| 660 | for line in `cat urls.lst`; do
|
---|
| 661 | IFS=$saveIFS # Restore the system defaults
|
---|
[3e7af38] | 662 |
|
---|
| 663 | # Skip some packages if they aren't needed
|
---|
[65d83a6] | 664 | case $line in
|
---|
[3e7af38] | 665 | */tcl* | */expect* | */dejagnu* | */tree* | */gcc-testsuite* )
|
---|
| 666 | [[ "$TEST" = "0" ]] && continue
|
---|
| 667 | ;;
|
---|
| 668 | */vim-*-lang* )
|
---|
| 669 | [[ "$VIMLANG" = "0" ]] && continue
|
---|
| 670 | ;;
|
---|
[3a27393] | 671 | *linux/linux-* )
|
---|
[34933b4] | 672 | [[ -z "$CONFIG" ]] && [[ -z "$BOOT_CONFIG" ]] && \
|
---|
[47fddc8] | 673 | [[ "$GETKERNEL" = "n" ]] && continue
|
---|
[3a27393] | 674 | ;;
|
---|
[65d83a6] | 675 | esac
|
---|
[3e7af38] | 676 |
|
---|
[65d83a6] | 677 | # Locations
|
---|
| 678 | URL1=`echo $line | cut -d" " -f2` # Preferred URL
|
---|
| 679 | URL2=`echo $line | cut -d" " -f1` # Fallback Upstream URL
|
---|
[7a100d96] | 680 | FILE=`basename $URL1` # File name
|
---|
| 681 | BOOKMD5=`echo $line | cut -d" " -f3` # MD5 book value
|
---|
| 682 |
|
---|
[3a27393] | 683 | # Validation pair
|
---|
| 684 | MD5="$BOOKMD5 $FILE"
|
---|
| 685 | HAVEMD5=1
|
---|
[0170229] | 686 |
|
---|
[65d83a6] | 687 | set -e
|
---|
| 688 | # If the file exists in the archive copy it to the
|
---|
| 689 | # $BUILDDIR/sources dir. MD5SUM will be validated later.
|
---|
| 690 | if [ ! -z ${SRC_ARCHIVE} ] &&
|
---|
| 691 | [ -d ${SRC_ARCHIVE} ] &&
|
---|
| 692 | [ -f ${SRC_ARCHIVE}/$FILE ]; then
|
---|
| 693 | cp ${SRC_ARCHIVE}/$FILE .
|
---|
| 694 | echo "$FILE: -- copied from $SRC_ARCHIVE"
|
---|
| 695 | fromARCHIVE=1
|
---|
| 696 | else
|
---|
| 697 | echo "${BOLD}${YELLOW}$FILE: not found in ${SRC_ARCHIVE}${OFF}"
|
---|
| 698 | fromARCHIVE=0
|
---|
[3a27393] | 699 | # If the file does not exist yet in /sources download a fresh one
|
---|
[3e7af38] | 700 | if [ ! -f $FILE ] ; then
|
---|
[65d83a6] | 701 | if ! wget $URL1 && ! wget $URL2 ; then
|
---|
| 702 | gs_wrt_message "$FILE not found in the SRC_ARCHIVE or on any server..SKIPPING"
|
---|
| 703 | continue
|
---|
| 704 | fi
|
---|
[3e7af38] | 705 | fi
|
---|
[65d83a6] | 706 | fi
|
---|
[0170229] | 707 |
|
---|
[3a27393] | 708 | # IF the md5sum does not match the existing files
|
---|
| 709 | if ! echo "$MD5" | md5sum -c - >/dev/null ; then
|
---|
| 710 | [[ $fromARCHIVE = "1" ]] && echo "${BOLD}${YELLOW}MD5SUM did not match SRC_ARCHIVE copy${OFF}"
|
---|
| 711 | [[ $fromARCHIVE = "0" ]] && echo "${BOLD}${YELLOW}MD5SUM did not match REMOTE copy${OFF}"
|
---|
| 712 | # Remove the old file and download a new one
|
---|
| 713 | rm -fv $FILE
|
---|
| 714 | # Force storage in SRC_ARCHIVE
|
---|
| 715 | fromARCHIVE=0;
|
---|
| 716 | # Try to retrieve again the file. Servers in reverse order.
|
---|
| 717 | if ! wget $URL2 && ! wget $URL1 ; then
|
---|
| 718 | gs_wrt_message "$FILE not found on the servers.. SKIPPING"
|
---|
| 719 | continue
|
---|
[3e7af38] | 720 | fi
|
---|
[65d83a6] | 721 | fi
|
---|
[e1edff3] | 722 |
|
---|
[65d83a6] | 723 | # Validate the MD5SUM one last time
|
---|
[3a27393] | 724 | if ! echo "$MD5" | md5sum -c - >/dev/null ; then
|
---|
[65d83a6] | 725 | gs_wrt_message "$FILE does not match MD5SUMS value"
|
---|
[b61a4a9] | 726 | # Force generation of MD5SUM
|
---|
| 727 | HAVEMD5=0
|
---|
[65d83a6] | 728 | fi
|
---|
[3e7af38] | 729 |
|
---|
[65d83a6] | 730 | # Generate a fresh MD5SUM for this file
|
---|
| 731 | if [[ "$HAVEMD5" = "0" ]] ; then
|
---|
| 732 | echo "${BOLD}${YELLOW}Generating a new MD5SUM for ${OFF}$FILE"
|
---|
[3a27393] | 733 | echo "NEW MD5SUM: $(md5sum $FILE)" >> MISSING_FILES.DMP
|
---|
[3e7af38] | 734 | fi
|
---|
[e1edff3] | 735 |
|
---|
[65d83a6] | 736 | # Good or bad we write the original md5sum to a file
|
---|
[3a27393] | 737 | echo "$MD5" >> MD5SUMS
|
---|
[65d83a6] | 738 |
|
---|
| 739 | # Copy the freshly downloaded file
|
---|
| 740 | # to the source archive.
|
---|
| 741 | if [ ! -z ${SRC_ARCHIVE} ] &&
|
---|
| 742 | [ -d ${SRC_ARCHIVE} ] &&
|
---|
| 743 | [ -w ${SRC_ARCHIVE} ] &&
|
---|
| 744 | [ "$fromARCHIVE" = "0" ] ; then
|
---|
| 745 | echo "Storing file:<$FILE> in the package archive"
|
---|
| 746 | cp -f $FILE ${SRC_ARCHIVE}
|
---|
| 747 | fi
|
---|
| 748 |
|
---|
| 749 | done
|
---|
| 750 |
|
---|
| 751 | if [[ -s MISSING_FILES.DMP ]]; then
|
---|
[3b63c8c] | 752 | echo -e "\n\n${tab_}${RED} One or more files were not retrieved or have bad MD5SUMS.\n${tab_} Check ${L_arrow}$BUILDDIR/sources/MISSING_FILES.DMP${R_arrow} for names ${OFF}\n"
|
---|
| 753 | # Do not allow the automatic execution of the Makefile.
|
---|
[65d83a6] | 754 | echo "${tab_}${BOLD}${RED}*** ${YELLOW}Automatic execution of the generated makefile has been inhibited. ${RED}***${OFF}${nl_}"
|
---|
[47fddc8] | 755 | RUNMAKE="n"
|
---|
[3e7af38] | 756 | fi
|
---|
[0170229] | 757 | }
|
---|
| 758 |
|
---|
| 759 | #----------------------------#
|
---|
[3e7af38] | 760 | create_urls() { #
|
---|
[0170229] | 761 | #----------------------------#
|
---|
[3e7af38] | 762 | cd $JHALFSDIR
|
---|
[0170229] | 763 |
|
---|
[3e7af38] | 764 | case ${PROGNAME} in
|
---|
| 765 | clfs)
|
---|
| 766 | echo -n "Creating CLFS <${ARCH}> specific URLs file"
|
---|
| 767 | xsltproc --nonet --xinclude \
|
---|
| 768 | --stringparam server $SERVER \
|
---|
| 769 | -o $BUILDDIR/sources/urls.lst urls.xsl \
|
---|
| 770 | $BOOK/materials/$ARCH-chapter.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 771 | echo " ...OK"
|
---|
| 772 | ;;
|
---|
[3b63c8c] | 773 | clfs2)
|
---|
| 774 | echo -n "Creating CLFS2 <${ARCH}> specific URLs file"
|
---|
| 775 | xsltproc --nonet --xinclude \
|
---|
| 776 | --stringparam server $SERVER \
|
---|
| 777 | -o $BUILDDIR/sources/urls.lst urls.xsl \
|
---|
| 778 | $BOOK/materials/$ARCH-chapter.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 779 | echo " ...OK"
|
---|
| 780 | ;;
|
---|
[3e7af38] | 781 | hlfs)
|
---|
| 782 | echo -n "Creating HLFS <${MODEL}> specific URLs file"
|
---|
| 783 | xsltproc --nonet --xinclude \
|
---|
| 784 | --stringparam server $SERVER \
|
---|
| 785 | --stringparam model $MODEL \
|
---|
| 786 | -o $BUILDDIR/sources/urls.lst urls.xsl \
|
---|
| 787 | $BOOK/chapter04/chapter04.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 788 | echo " ...OK"
|
---|
| 789 | ;;
|
---|
| 790 | lfs)
|
---|
| 791 | echo -n "Creating LFS specific URLs file"
|
---|
| 792 | xsltproc --nonet --xinclude \
|
---|
| 793 | --stringparam server $SERVER \
|
---|
| 794 | -o ../sources/urls.lst urls.xsl \
|
---|
| 795 | $BOOK/chapter03/chapter03.xml >>$LOGDIR/$LOG 2>&1
|
---|
| 796 | echo " ...OK"
|
---|
| 797 | ;;
|
---|
| 798 | esac
|
---|
[0170229] | 799 |
|
---|
[3e7af38] | 800 | cd $BUILDDIR/sources
|
---|
[865f4f6] | 801 |
|
---|
| 802 | [[ "${BLFS_TOOL}" = "y" ]] && add_blfs_deps_urls
|
---|
| 803 | }
|
---|
| 804 |
|
---|
| 805 | #----------------------------# Hardcoded URLs and MD5.
|
---|
| 806 | add_blfs_deps_urls() { # No easy way to extract it.
|
---|
| 807 | #----------------------------# Some FTP mirrors may not work
|
---|
| 808 |
|
---|
| 809 | local BLFS_SERVER="${SERVER}/pub/blfs/conglomeration/"
|
---|
| 810 |
|
---|
| 811 | if [[ "${DEP_LIBXML}" = "y" ]] ; then
|
---|
[c03e5d0] | 812 | echo "${LIBXML_URL} ${BLFS_SERVER}libxml2/${LIBXML_PKG} ${LIBXML_MD5}" >> urls.lst
|
---|
[865f4f6] | 813 | fi
|
---|
| 814 |
|
---|
| 815 | if [[ "${DEP_LIBXSLT}" = "y" ]] ; then
|
---|
[c03e5d0] | 816 | echo "${LIBXSLT_URL} ${BLFS_SERVER}libxslt/${LIBXSLT_PKG} ${LIBXSLT_MD5}" >> urls.lst
|
---|
[865f4f6] | 817 | fi
|
---|
| 818 |
|
---|
| 819 | if [[ "${DEP_DBXSL}" = "y" ]] ; then
|
---|
[c03e5d0] | 820 | echo "${DBXSL_URL} ${BLFS_SERVER}docbook-xsl/${DBXSL_PKG} ${DBXSL_MD5}" >> urls.lst
|
---|
[865f4f6] | 821 | fi
|
---|
| 822 |
|
---|
[c03e5d0] | 823 | if [[ "${DEP_LINKS}" = "y" ]] ; then
|
---|
| 824 | echo "${LINKS_URL} ${BLFS_SERVER}links/${LINKS_PKG} ${LINKS_MD5}" >> urls.lst
|
---|
[865f4f6] | 825 | fi
|
---|
| 826 |
|
---|
| 827 | if [[ "${DEP_SUDO}" = "y" ]] ; then
|
---|
[c03e5d0] | 828 | echo "${SUDO_URL} ${BLFS_SERVER}sudo/${SUDO_PKG} ${SUDO_MD5}" >> urls.lst
|
---|
[3c5ca23] | 829 | echo "${SUDO_PATCH_URL} ${BLFS_SERVER}sudo/${SUDO_PATCH} ${SUDO_PATCH_MD5}" >> urls.lst
|
---|
[865f4f6] | 830 | fi
|
---|
| 831 |
|
---|
| 832 | if [[ "${DEP_WGET}" = "y" ]] ; then
|
---|
[c03e5d0] | 833 | echo "${WGET_URL} ${BLFS_SERVER}wget/${WGET_PKG} ${WGET_MD5}" >> urls.lst
|
---|
[865f4f6] | 834 | fi
|
---|
| 835 |
|
---|
| 836 | if [[ "${DEP_SVN}" = "y" ]] ; then
|
---|
[c03e5d0] | 837 | echo "${SVN_URL} ${BLFS_SERVER}subversion/${SVN_PKG} ${SVN_MD5}" >> urls.lst
|
---|
[865f4f6] | 838 | fi
|
---|
| 839 |
|
---|
| 840 | if [[ "${DEP_GPM}" = "y" ]] ; then
|
---|
[c03e5d0] | 841 | echo "${GPM_URL} ${BLFS_SERVER}gpm/${GPM_PKG} ${GPM_MD5}" >> urls.lst
|
---|
[3c5ca23] | 842 | echo "${GPM_PATCH_1_URL} ${BLFS_SERVER}gpm/${GPM_PATCH_1} ${GPM_PATCH_1_MD5}" >> urls.lst
|
---|
| 843 | echo "${GPM_PATCH_2_URL} ${BLFS_SERVER}gpm/${GPM_PATCH_2} ${GPM_PATCH_2_MD5}" >> urls.lst
|
---|
[865f4f6] | 844 | fi
|
---|
| 845 |
|
---|
[0170229] | 846 | }
|
---|
[3c5ca23] | 847 |
|
---|
| 848 | #----------------------------# Maybe there is a better way to do this, but this
|
---|
| 849 | copy_blfs_deps_scripts() { # method avoid to place the test on all
|
---|
| 850 | #----------------------------# $PROGNAME/master.sh scripts.
|
---|
| 851 |
|
---|
| 852 | mkdir -p ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 853 |
|
---|
| 854 | if [[ "${DEP_LIBXML}" = "y" ]] ; then
|
---|
| 855 | mv blfs-tool-deps/901-libxml2 ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 856 | fi
|
---|
| 857 |
|
---|
| 858 | if [[ "${DEP_LIBXSLT}" = "y" ]] ; then
|
---|
| 859 | mv blfs-tool-deps/902-libxslt ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 860 | fi
|
---|
| 861 |
|
---|
| 862 | if [[ "${DEP_DBXSL}" = "y" ]] ; then
|
---|
| 863 | mv blfs-tool-deps/903-docbook-xsl ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 864 | fi
|
---|
| 865 |
|
---|
| 866 | if [[ "${DEP_LINKS}" = "y" ]] ; then
|
---|
| 867 | mv blfs-tool-deps/905-links ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 868 | fi
|
---|
| 869 |
|
---|
| 870 | if [[ "${DEP_SUDO}" = "y" ]] ; then
|
---|
| 871 | mv blfs-tool-deps/906-sudo ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 872 | fi
|
---|
| 873 |
|
---|
| 874 | if [[ "${DEP_WGET}" = "y" ]] ; then
|
---|
| 875 | mv blfs-tool-deps/907-wget ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 876 | fi
|
---|
| 877 |
|
---|
| 878 | if [[ "${DEP_SVN}" = "y" ]] ; then
|
---|
| 879 | mv blfs-tool-deps/908-subversion ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 880 | fi
|
---|
| 881 |
|
---|
| 882 | if [[ "${DEP_GPM}" = "y" ]] ; then
|
---|
| 883 | mv blfs-tool-deps/904-gpm ${PROGNAME}-commands/blfs-tool-deps
|
---|
| 884 | fi
|
---|
| 885 |
|
---|
| 886 | rm -rf blfs-tool-deps
|
---|
| 887 |
|
---|
[44994cb] | 888 | }
|
---|