From 554a1c699f6716db6e148959491b7d36b2584190 Mon Sep 17 00:00:00 2001 From: Anton Skshidlevsky Date: Tue, 16 Jul 2013 21:10:18 +0400 Subject: [PATCH] 1.4.0 Former-commit-id: 76dcbbfa06fca3310f9d7c0de5b550277a22f76f --- .classpath | 4 +- AndroidManifest.xml | 7 +- CHANGELOG | 8 + assets/home/deploy/debootstrap/scripts/etch | 192 +++++++++++++++- .../home/deploy/debootstrap/scripts/etch-m68k | 192 +++++++++++++++- assets/home/deploy/debootstrap/scripts/hardy | 215 +++++++++++++++++- .../home/deploy/debootstrap/scripts/intrepid | 215 +++++++++++++++++- assets/home/deploy/debootstrap/scripts/jaunty | 215 +++++++++++++++++- assets/home/deploy/debootstrap/scripts/kali | 192 +++++++++++++++- assets/home/deploy/debootstrap/scripts/karmic | 215 +++++++++++++++++- assets/home/deploy/debootstrap/scripts/lenny | 192 +++++++++++++++- assets/home/deploy/debootstrap/scripts/lucid | 215 +++++++++++++++++- .../home/deploy/debootstrap/scripts/maverick | 215 +++++++++++++++++- assets/home/deploy/debootstrap/scripts/natty | 215 +++++++++++++++++- .../home/deploy/debootstrap/scripts/oldstable | 192 +++++++++++++++- .../home/deploy/debootstrap/scripts/oneiric | 215 +++++++++++++++++- .../home/deploy/debootstrap/scripts/precise | 215 +++++++++++++++++- .../home/deploy/debootstrap/scripts/quantal | 215 +++++++++++++++++- assets/home/deploy/debootstrap/scripts/raring | 215 +++++++++++++++++- .../home/deploy/debootstrap/scripts/squeeze | 192 +++++++++++++++- assets/home/deploy/debootstrap/scripts/stable | 192 +++++++++++++++- .../home/deploy/debootstrap/scripts/testing | 192 +++++++++++++++- .../home/deploy/debootstrap/scripts/unstable | 192 +++++++++++++++- assets/home/deploy/debootstrap/scripts/wheezy | 192 +++++++++++++++- libs/android-support-v4.jar | Bin 385685 -> 484258 bytes lint.xml | 1 - project.properties | 2 +- res/menu/activity_profiles.xml | 12 + res/values-ru/strings.xml | 8 + res/values/strings.xml | 8 + src/ru/meefik/linuxdeploy/PrefStore.java | 60 +++++ .../meefik/linuxdeploy/ProfilesActivity.java | 112 ++++++++- 32 files changed, 4474 insertions(+), 33 deletions(-) mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/etch mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/etch-m68k mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/hardy mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/intrepid mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/jaunty mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/kali mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/karmic mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/lenny mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/lucid mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/maverick mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/natty mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/oldstable mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/oneiric mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/precise mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/quantal mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/raring mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/squeeze mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/stable mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/testing mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/unstable mode change 120000 => 100644 assets/home/deploy/debootstrap/scripts/wheezy diff --git a/.classpath b/.classpath index bb0c7597..c06dfcb8 100644 --- a/.classpath +++ b/.classpath @@ -1,9 +1,9 @@ - - + + diff --git a/AndroidManifest.xml b/AndroidManifest.xml index b9ecabf7..89514f2a 100644 --- a/AndroidManifest.xml +++ b/AndroidManifest.xml @@ -1,12 +1,11 @@ + android:versionCode="73" + android:versionName="1.4.0" > + android:minSdkVersion="7" android:targetSdkVersion="16"/> diff --git a/CHANGELOG b/CHANGELOG index a688f152..b242c4e1 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,6 +1,10 @@ Changelog (English) =================== +1.4.0 +Added function of import/export profiles +Support Android 2.1 (API 7) + 1.3.9 Added support Gentoo (installation requires at least 4 GB of free space) Limitation of scroll buffer size @@ -202,6 +206,10 @@ Updated list packages of base system installation История изменений (Русский) =========================== +1.4.0 +Добавлена ​​функция импорта/экспорта профилей. +Поддержка Android 2.1 (API 7) + 1.3.9 Добавлена поддержка Gentoo (для установки необходимо не менее 4 GB свободного места) Ограничение размера буфера прокрутки diff --git a/assets/home/deploy/debootstrap/scripts/etch b/assets/home/deploy/debootstrap/scripts/etch deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/etch +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/etch b/assets/home/deploy/debootstrap/scripts/etch new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/etch @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/etch-m68k b/assets/home/deploy/debootstrap/scripts/etch-m68k deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/etch-m68k +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/etch-m68k b/assets/home/deploy/debootstrap/scripts/etch-m68k new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/etch-m68k @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/hardy b/assets/home/deploy/debootstrap/scripts/hardy deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/hardy +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/hardy b/assets/home/deploy/debootstrap/scripts/hardy new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/hardy @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/intrepid b/assets/home/deploy/debootstrap/scripts/intrepid deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/intrepid +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/intrepid b/assets/home/deploy/debootstrap/scripts/intrepid new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/intrepid @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/jaunty b/assets/home/deploy/debootstrap/scripts/jaunty deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/jaunty +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/jaunty b/assets/home/deploy/debootstrap/scripts/jaunty new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/jaunty @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/kali b/assets/home/deploy/debootstrap/scripts/kali deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/kali +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/kali b/assets/home/deploy/debootstrap/scripts/kali new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/kali @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/karmic b/assets/home/deploy/debootstrap/scripts/karmic deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/karmic +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/karmic b/assets/home/deploy/debootstrap/scripts/karmic new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/karmic @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/lenny b/assets/home/deploy/debootstrap/scripts/lenny deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/lenny +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/lenny b/assets/home/deploy/debootstrap/scripts/lenny new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/lenny @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/lucid b/assets/home/deploy/debootstrap/scripts/lucid deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/lucid +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/lucid b/assets/home/deploy/debootstrap/scripts/lucid new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/lucid @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/maverick b/assets/home/deploy/debootstrap/scripts/maverick deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/maverick +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/maverick b/assets/home/deploy/debootstrap/scripts/maverick new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/maverick @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/natty b/assets/home/deploy/debootstrap/scripts/natty deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/natty +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/natty b/assets/home/deploy/debootstrap/scripts/natty new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/natty @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/oldstable b/assets/home/deploy/debootstrap/scripts/oldstable deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/oldstable +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/oldstable b/assets/home/deploy/debootstrap/scripts/oldstable new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/oldstable @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/oneiric b/assets/home/deploy/debootstrap/scripts/oneiric deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/oneiric +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/oneiric b/assets/home/deploy/debootstrap/scripts/oneiric new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/oneiric @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/precise b/assets/home/deploy/debootstrap/scripts/precise deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/precise +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/precise b/assets/home/deploy/debootstrap/scripts/precise new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/precise @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/quantal b/assets/home/deploy/debootstrap/scripts/quantal deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/quantal +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/quantal b/assets/home/deploy/debootstrap/scripts/quantal new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/quantal @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/raring b/assets/home/deploy/debootstrap/scripts/raring deleted file mode 120000 index 3840936c..00000000 --- a/assets/home/deploy/debootstrap/scripts/raring +++ /dev/null @@ -1 +0,0 @@ -gutsy \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/raring b/assets/home/deploy/debootstrap/scripts/raring new file mode 100644 index 00000000..90e1d5dd --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/raring @@ -0,0 +1,214 @@ +case $ARCH in + amd64|i386) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + sparc) + case $SUITE in + gutsy) + default_mirror http://archive.ubuntu.com/ubuntu + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; + esac + ;; + *) + default_mirror http://ports.ubuntu.com/ubuntu-ports + ;; +esac +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase +keyring /usr/share/keyrings/ubuntu-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant -; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd; then + base="$(get_debs Build-Essential: yes)" + elif doing_variant fakechroot || doing_variant minbase; then + base="apt" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + setup_devices + + if doing_variant fakechroot; then + setup_proc_fakechroot + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/Etc/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1 + + info CONFREQ "Configuring required packages..." + + if doing_variant fakechroot; then + # fix initscripts postinst (no mounting possible, and wrong if condition) + sed -i '/dpkg.*--compare-versions/ s/\/lt-nl/' "$TARGET/var/lib/dpkg/info/initscripts.postinst" + fi + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + if [ -x "$TARGET/sbin/initctl" ]; then + mv "$TARGET/sbin/initctl" "$TARGET/sbin/initctl.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake initctl called, doing nothing\"" > "$TARGET/sbin/initctl" + chmod 755 "$TARGET/sbin/initctl" + fi + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1 + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1 + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1 + + if [ -x "$TARGET/sbin/initctl.REAL" ]; then + mv "$TARGET/sbin/initctl.REAL" "$TARGET/sbin/initctl" + fi + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/squeeze b/assets/home/deploy/debootstrap/scripts/squeeze deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/squeeze +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/squeeze b/assets/home/deploy/debootstrap/scripts/squeeze new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/squeeze @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/stable b/assets/home/deploy/debootstrap/scripts/stable deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/stable +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/stable b/assets/home/deploy/debootstrap/scripts/stable new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/stable @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/testing b/assets/home/deploy/debootstrap/scripts/testing deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/testing +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/testing b/assets/home/deploy/debootstrap/scripts/testing new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/testing @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/unstable b/assets/home/deploy/debootstrap/scripts/unstable deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/unstable +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/unstable b/assets/home/deploy/debootstrap/scripts/unstable new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/unstable @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/assets/home/deploy/debootstrap/scripts/wheezy b/assets/home/deploy/debootstrap/scripts/wheezy deleted file mode 120000 index 9a63c961..00000000 --- a/assets/home/deploy/debootstrap/scripts/wheezy +++ /dev/null @@ -1 +0,0 @@ -sid \ No newline at end of file diff --git a/assets/home/deploy/debootstrap/scripts/wheezy b/assets/home/deploy/debootstrap/scripts/wheezy new file mode 100644 index 00000000..893d5d5c --- /dev/null +++ b/assets/home/deploy/debootstrap/scripts/wheezy @@ -0,0 +1,191 @@ +mirror_style release +download_style apt +finddebs_style from-indices +variants - buildd fakechroot minbase scratchbox +keyring /usr/share/keyrings/debian-archive-keyring.gpg + +if doing_variant fakechroot; then + test "$FAKECHROOT" = "true" || error 1 FAKECHROOTREQ "This variant requires fakechroot environment to be started" +fi + +case $ARCH in + alpha|ia64) LIBC="libc6.1" ;; + kfreebsd-*) LIBC="libc0.1" ;; + hurd-*) LIBC="libc0.3" ;; + *) LIBC="libc6" ;; +esac + +work_out_debs () { + required="$(get_debs Priority: required)" + + if doing_variant - || doing_variant fakechroot; then + #required="$required $(get_debs Priority: important)" + # ^^ should be getting debconf here somehow maybe + base="$(get_debs Priority: important)" + elif doing_variant buildd || doing_variant scratchbox; then + base="apt build-essential" + elif doing_variant minbase; then + base="apt" + fi + + if doing_variant fakechroot; then + # ldd.fake needs binutils + required="$required binutils" + fi +} + +first_stage_install () { + extract $required + + mkdir -p "$TARGET/var/lib/dpkg" + : >"$TARGET/var/lib/dpkg/status" + : >"$TARGET/var/lib/dpkg/available" + + setup_etc + if [ ! -e "$TARGET/etc/fstab" ]; then + echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab" + chown 0:0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab" + fi + + x_feign_install () { + local pkg="$1" + local deb="$(debfor $pkg)" + local ver="$(extract_deb_field "$TARGET/$deb" Version)" + + mkdir -p "$TARGET/var/lib/dpkg/info" + + echo \ +"Package: $pkg +Version: $ver +Maintainer: unknown +Status: install ok installed" >> "$TARGET/var/lib/dpkg/status" + + touch "$TARGET/var/lib/dpkg/info/${pkg}.list" + } + + x_feign_install dpkg +} + +second_stage_install () { + setup_devices + + x_core_install () { + smallyes '' | in_target dpkg --force-depends --install $(debfor "$@") + } + + p () { + baseprog="$(($baseprog + ${1:-1}))" + } + + if doing_variant fakechroot; then + setup_proc_fakechroot + elif doing_variant scratchbox; then + true + else + setup_proc + in_target /sbin/ldconfig + fi + + DEBIAN_FRONTEND=noninteractive + DEBCONF_NONINTERACTIVE_SEEN=true + export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN + + baseprog=0 + bases=7 + + p; progress $baseprog $bases INSTCORE "Installing core packages" #1 + info INSTCORE "Installing core packages..." + + p; progress $baseprog $bases INSTCORE "Installing core packages" #2 + ln -sf mawk "$TARGET/usr/bin/awk" + x_core_install base-files base-passwd + p; progress $baseprog $bases INSTCORE "Installing core packages" #3 + x_core_install dpkg + + if [ ! -e "$TARGET/etc/localtime" ]; then + ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime" + fi + + if doing_variant fakechroot; then + install_fakechroot_tools + fi + + p; progress $baseprog $bases INSTCORE "Installing core packages" #4 + x_core_install $LIBC + + p; progress $baseprog $bases INSTCORE "Installing core packages" #5 + x_core_install perl-base + + p; progress $baseprog $bases INSTCORE "Installing core packages" #6 + rm "$TARGET/usr/bin/awk" + x_core_install mawk + + p; progress $baseprog $bases INSTCORE "Installing core packages" #7 + if doing_variant -; then + x_core_install debconf + fi + + baseprog=0 + bases=$(set -- $required; echo $#) + + info UNPACKREQ "Unpacking required packages..." + + exec 7>&1 + + smallyes '' | + (repeatn 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages. This will be attempted up to five times." "" \ + dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING + + info CONFREQ "Configuring required packages..." + + mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL" + echo \ +"#!/bin/sh +echo +echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon" + chmod 755 "$TARGET/sbin/start-stop-daemon" + + setup_dselect_method apt + + smallyes '' | + (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \ + dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING + + baseprog=0 + bases="$(set -- $base; echo $#)" + + info UNPACKBASE "Unpacking the base system..." + + setup_available $required $base + done_predeps= + while predep=$(get_next_predep); do + # We have to resolve dependencies of pre-dependencies manually because + # dpkg --predep-package doesn't handle this. + predep=$(without "$(without "$(resolve_deps $predep)" "$required")" "$done_predeps") + # XXX: progress is tricky due to how dpkg_progress works + # -- cjwatson 2009-07-29 + p; smallyes '' | + in_target dpkg --force-overwrite --force-confold --skip-same-version --install $(debfor $predep) + base=$(without "$base" "$predep") + done_predeps="$done_predeps $predep" + done + + smallyes '' | + (repeatn 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING + + info CONFBASE "Configuring the base system..." + + smallyes '' | + (repeatn 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages. This will be re-attempted up to five times." "" \ + dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 || echo EXITCODE $?) | + dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING + + mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon" + + progress $bases $bases CONFBASE "Configuring base system" + info BASESUCCESS "Base system installed successfully." +} diff --git a/libs/android-support-v4.jar b/libs/android-support-v4.jar index 6080877d4ade158f24ad7ccd9a10db2ac9060b47..428bdbc02a1aa32649e236e0734261bd68bc4e6f 100644 GIT binary patch delta 183916 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
OcjGE9 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
>NmBQqouA)R+VVw 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 delta 89623 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 =@WOn5vyl~urFWaP?Kw8nIl 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 AnE(I) diff --git a/lint.xml b/lint.xml index 791d4c8c..ee0eead5 100644 --- a/lint.xml +++ b/lint.xml @@ -1,4 +1,3 @@ - \ No newline at end of file diff --git a/project.properties b/project.properties index 0dc002cf..7b6ccac4 100644 --- a/project.properties +++ b/project.properties @@ -12,4 +12,4 @@ # Project target. target=android-17 -android.library.reference.1=../ActionBarSherlock +android.library.reference.1=../actionbarsherlock diff --git a/res/menu/activity_profiles.xml b/res/menu/activity_profiles.xml index 3f877589..45a20972 100644 --- a/res/menu/activity_profiles.xml +++ b/res/menu/activity_profiles.xml @@ -21,5 +21,17 @@ android:showAsAction="always" android:title="@string/menu_discard"> + + + + \ No newline at end of file diff --git a/res/values-ru/strings.xml b/res/values-ru/strings.xml index 9940033f..21eb7409 100644 --- a/res/values-ru/strings.xml +++ b/res/values-ru/strings.xml @@ -13,6 +13,8 @@ Добавить Изменить Удалить + Импортировать + Экспортировать Текущий профиль Linux Deploy О программе @@ -25,6 +27,12 @@ Остановить сервисы и размонтировать GNU/Linux? Имя профиля Имя профиля + Импортировать профиль + Экспортировать профиль + Профиль успешно импортирован. + Ошибка импорта профиля! + Профиль успешно экспортирован. + Ошибка экспорта профиля! Удаление профиля Удалить выбранный профиль? Приложение diff --git a/res/values/strings.xml b/res/values/strings.xml index 698694eb..3d5833c6 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -13,6 +13,8 @@ New Edit Delete + Import + Export Current profile Linux Deploy About @@ -25,6 +27,12 @@ Stop services and unmount GNU/Linux system? Profile name Profile name + Import profile + Export profile + Profile has been successfully imported. + Error importing profile! + Profile has been successfully exported. + Error exporting profile! Remove profile Remove selected profile? Application diff --git a/src/ru/meefik/linuxdeploy/PrefStore.java b/src/ru/meefik/linuxdeploy/PrefStore.java index d1916dfa..b383dc24 100644 --- a/src/ru/meefik/linuxdeploy/PrefStore.java +++ b/src/ru/meefik/linuxdeploy/PrefStore.java @@ -1,9 +1,13 @@ package ru.meefik.linuxdeploy; import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.IOException; import java.net.InetAddress; import java.net.NetworkInterface; import java.net.SocketException; +import java.nio.channels.FileChannel; import java.util.ArrayList; import java.util.Enumeration; import java.util.Locale; @@ -14,6 +18,7 @@ import android.content.pm.PackageManager.NameNotFoundException; import android.content.res.Configuration; import android.os.Environment; +import android.util.Log; public class PrefStore { @@ -280,6 +285,61 @@ public static void deleteProfile(Context c, String key) { if (f.exists()) f.delete(); } + + // import profile + public static boolean importProfile(Context c, String key, String src) { + String fPref = "../shared_prefs/" + key + ".xml"; + File destFile = new File(c.getFilesDir(), fPref); + File sourceFile = new File(src); + if (sourceFile.exists()) { + try { + copyFile(sourceFile, destFile); + return true; + } catch (IOException e) { + e.printStackTrace(); + } + } + return false; + } + + // export profile + public static boolean exportProfile(Context c, String key, String dst) { + String fPref = "../shared_prefs/" + key + ".xml"; + File sourceFile = new File(c.getFilesDir(), fPref); + File destFile = new File(dst); + if (sourceFile.exists()) { + try { + copyFile(sourceFile, destFile); + return true; + } catch (IOException e) { + e.printStackTrace(); + } + } + return false; + } + + public static void copyFile(File sourceFile, File destFile) throws IOException { + if(!destFile.exists()) { + destFile.createNewFile(); + } + + FileChannel source = null; + FileChannel destination = null; + + try { + source = new FileInputStream(sourceFile).getChannel(); + destination = new FileOutputStream(destFile).getChannel(); + destination.transferFrom(source, 0, source.size()); + } + finally { + if(source != null) { + source.close(); + } + if(destination != null) { + destination.close(); + } + } + } // multilanguage support public static void updateLocale(Context c) { diff --git a/src/ru/meefik/linuxdeploy/ProfilesActivity.java b/src/ru/meefik/linuxdeploy/ProfilesActivity.java index 4e31f60f..937be284 100644 --- a/src/ru/meefik/linuxdeploy/ProfilesActivity.java +++ b/src/ru/meefik/linuxdeploy/ProfilesActivity.java @@ -1,5 +1,6 @@ package ru.meefik.linuxdeploy; +import java.io.File; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; @@ -7,6 +8,7 @@ import android.app.AlertDialog; import android.content.DialogInterface; import android.os.Bundle; +import android.os.Environment; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.View; @@ -14,6 +16,7 @@ import android.widget.ArrayAdapter; import android.widget.EditText; import android.widget.ListView; +import android.widget.Toast; import com.actionbarsherlock.app.SherlockActivity; import com.actionbarsherlock.view.Menu; @@ -63,6 +66,7 @@ public boolean onCreateOptionsMenu(Menu menu) { public boolean onOptionsItemSelected(MenuItem item) { final EditText input = new EditText(this); final int pos = profilesList.getCheckedItemPosition(); + File extStore = Environment.getExternalStorageDirectory(); switch (item.getItemId()) { case R.id.menu_new: new AlertDialog.Builder(this) @@ -74,8 +78,7 @@ public boolean onOptionsItemSelected(MenuItem item) { public void onClick(DialogInterface dialog, int whichButton) { String pName = input.getText().toString(); - if (pName.length() > 0 - && listItems.indexOf(pName) < 0) { + if (pName.length() > 0) { listItems .add(new Profile( String.valueOf(System @@ -108,8 +111,7 @@ public void onClick(DialogInterface dialog, int whichButton) { String pName = input.getText() .toString(); - if (pName.length() > 0 - && listItems.indexOf(pName) < 0) { + if (pName.length() > 0) { listItems .set(pos, new Profile( @@ -165,6 +167,108 @@ public void onClick(DialogInterface dialog, }).show(); } break; + case R.id.menu_import: + String srcFile = extStore.getAbsolutePath() + "/linux.xml"; + input.setText(srcFile); + input.setSelection(input.getText().length()); + new AlertDialog.Builder(this) + .setTitle(R.string.import_profile_title) + .setView(input) + .setPositiveButton(android.R.string.ok, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, + int whichButton) { + String profilePath = input.getText() + .toString(); + String key = String.valueOf(System + .currentTimeMillis()); + if (PrefStore.importProfile( + getApplicationContext(), key, + profilePath)) { + String profileFile = new File( + profilePath).getName(); + String profileName = profileFile + .replaceAll("^(.*).xml$", "$1"); + + listItems + .add(new Profile( + key, profileName)); + adapter.notifyDataSetChanged(); + + Toast toast = Toast + .makeText( + getApplicationContext(), + getString(R.string.toast_import_profile_success), + Toast.LENGTH_SHORT); + toast.show(); + } else { + Toast toast = Toast + .makeText( + getApplicationContext(), + getString(R.string.toast_import_profile_error), + Toast.LENGTH_SHORT); + toast.show(); + } + } + }) + .setNegativeButton(android.R.string.cancel, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, + int whichButton) { + dialog.cancel(); + } + }).show(); + break; + case R.id.menu_export: + if (pos >= 0 && pos < listItems.size()) { + String validFileName = listItems.get(pos).getValue() + .replaceAll("[^0-9a-zA-Z_-]", "_"); + String dstFile = extStore.getAbsolutePath() + "/" + + validFileName + ".xml"; + input.setText(dstFile); + input.setSelection(input.getText().length()); + new AlertDialog.Builder(this) + .setTitle(R.string.export_profile_title) + .setView(input) + .setPositiveButton(android.R.string.ok, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, + int whichButton) { + String pName = input.getText() + .toString(); + if (PrefStore.exportProfile( + getApplicationContext(), + listItems.get(pos).getKey(), + pName)) { + Toast toast = Toast + .makeText( + getApplicationContext(), + getString(R.string.toast_export_profile_success), + Toast.LENGTH_SHORT); + toast.show(); + } else { + Toast toast = Toast + .makeText( + getApplicationContext(), + getString(R.string.toast_export_profile_error), + Toast.LENGTH_SHORT); + toast.show(); + } + } + }) + .setNegativeButton(android.R.string.cancel, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, + int whichButton) { + dialog.cancel(); + } + }).show(); + } + break; } return false; }