mkarchiso: cleanup opts, user dir creation

As in title, this patch cleans up opt flags that exist for no reason and
adds additional flags to modify the disk meta info which would otherwise
be hardcoded.

I wasn't quite sure about the user directory part but it doesn't seem
like a good idea to put that part into the script and therefore I
commented it out. It would probably interfere with rc.local scripts that
take care of skel copying. I replaced the part after the TODO with a
safe guard to make sure that people who are not aware of the changes
will not be caught by surprise.

Signed-off-by: Aaron Griffin <aaronmgriffin@gmail.com>
This commit is contained in:
Sven-Hendrik Haase 2009-10-22 11:21:16 +02:00 committed by Aaron Griffin
parent 44550defdb
commit 961d4cb670

View File

@ -4,6 +4,10 @@ PKGLIST=""
QUIET="y" QUIET="y"
FORCE="n" FORCE="n"
PACCONFIG="/etc/pacman.conf" PACCONFIG="/etc/pacman.conf"
export LABEL="ARCHISO_$(pwgen -n 8 1 | tr [a-z] [A-Z])"
PUBLISHER="Arch Linux <http://www.archlinux.org>"
APPLICATION="Arch Linux Live/Rescue CD"
CREATE_DEFAULT="n"
APPNAME=$(basename "${0}") APPNAME=$(basename "${0}")
@ -15,8 +19,12 @@ usage ()
echo " -f Force overwrite of working files/squashfs image/bootable image" echo " -f Force overwrite of working files/squashfs image/bootable image"
echo " -p PACKAGE(S) Additional package(s) to install, can be used multiple times" echo " -p PACKAGE(S) Additional package(s) to install, can be used multiple times"
echo " -C <file> Config file for pacman. Default $PACCONFIG" echo " -C <file> Config file for pacman. Default $PACCONFIG"
echo " -v Enable verbose output." echo " -L <label> Set a label for the disk"
echo " -h This message." echo " -P <publisher> Set a publisher for the disk"
echo " -A <application> Set an application name for the disk"
echo " -d Create default user directory /home/arch"
echo " -v Enable verbose output"
echo " -h This message"
echo " commands:" echo " commands:"
echo " create <dir>" echo " create <dir>"
echo " create a base directory layout to work with" echo " create a base directory layout to work with"
@ -28,10 +36,14 @@ usage ()
exit $1 exit $1
} }
while getopts 'C:i:P:p:a:t:fvh' arg; do while getopts 'p:C:L:P:A:dfvh' arg; do
case "${arg}" in case "${arg}" in
p) PKGLIST="${PKGLIST} ${OPTARG}" ;; p) PKGLIST="${PKGLIST} ${OPTARG}" ;;
C) PACCONFIG="${OPTARG}" ;; C) PACCONFIG="${OPTARG}" ;;
L) LABEL="${OPTARG}" ;;
P) PUBLISHER="${OPTARG}" ;;
A) APPLICATION="${OPTARG}" ;;
d) CREATE_DEFAULT="y" ;;
f) FORCE="y" ;; f) FORCE="y" ;;
v) QUIET="n" ;; v) QUIET="n" ;;
h|?) usage 0 ;; h|?) usage 0 ;;
@ -134,9 +146,11 @@ to the iso/ directory.
fi fi
#TODO is this needed? do it at the Makefile level? #TODO is this needed? do it at the Makefile level?
if [ -d "${work_dir}/root-image/home/" ]; then if [ ${CREATE_DEFAULT} == "y" ]; then
echo "Creating default home directory" if [ -d "${work_dir}/root-image/home/" ]; then
install -d -o1000 -g100 -m0755 "${work_dir}/root-image/home/arch" echo "Creating default home directory"
install -d -o1000 -g100 -m0755 "${work_dir}/root-image/home/arch"
fi
fi fi
# delete a lot of unnecessary cache/log files # delete a lot of unnecessary cache/log files
@ -215,7 +229,6 @@ _imgcommon () {
cp "${work_dir}/isomounts" "${work_dir}/iso/" cp "${work_dir}/isomounts" "${work_dir}/iso/"
export LABEL="ARCHISO_$(pwgen -n 8 1 | tr [a-z] [A-Z])"
[ -f ${work_dir}/iso/boot/grub/menu.lst ] && sed "s|archisolabel=[^ ]*|archisolabel=${LABEL}|" -i ${work_dir}/iso/boot/grub/menu.lst [ -f ${work_dir}/iso/boot/grub/menu.lst ] && sed "s|archisolabel=[^ ]*|archisolabel=${LABEL}|" -i ${work_dir}/iso/boot/grub/menu.lst
[ -f ${work_dir}/iso/boot/isolinux/isolinux.cfg ] && sed "s|archisolabel=[^ ]*|archisolabel=${LABEL}|" -i ${work_dir}/iso/boot/isolinux/isolinux.cfg [ -f ${work_dir}/iso/boot/isolinux/isolinux.cfg ] && sed "s|archisolabel=[^ ]*|archisolabel=${LABEL}|" -i ${work_dir}/iso/boot/isolinux/isolinux.cfg
} }
@ -251,10 +264,11 @@ command_iso () {
qflag="" qflag=""
[ "${QUIET}" = "y" ] && qflag="-quiet" [ "${QUIET}" = "y" ] && qflag="-quiet"
mkisofs ${qflag} -r -l $bootflags -uid 0 -gid 0 \ mkisofs ${qflag} -r -l $bootflags -uid 0 -gid 0 \
-udf -allow-limited-size -iso-level 3 \
-input-charset utf-8 -p "prepared by mkarchiso" \ -input-charset utf-8 -p "prepared by mkarchiso" \
-no-emul-boot -boot-load-size 4 -boot-info-table \ -no-emul-boot -boot-load-size 4 -boot-info-table \
-publisher "Arch Linux <http://www.archlinux.org>" \ -publisher "${PUBLISHER}" \
-A "Arch Linux Live/Rescue CD" \ -A "${APPLICATION}" \
-V "${LABEL}" \ -V "${LABEL}" \
-o "${imgname}" "${work_dir}/iso/" -o "${imgname}" "${work_dir}/iso/"
} }