ready for tagging
[util-vserver.git] / distrib / dapper / debootstrap.script
1 case $ARCH in
2   amd64|i386|powerpc|sparc)
3     default_mirror http://archive.ubuntu.com/ubuntu
4     ;;
5   *)
6     default_mirror http://ports.ubuntu.com/ubuntu-ports
7     ;;
8 esac
9 mirror_style release
10 download_style apt
11 finddebs_style from-indices
12 variants - buildd
13
14 work_out_debs () {
15     LIBC6=libc6
16     if [ "$ARCH" = "alpha" -o "$ARCH" = "ia64" ]; then LIBC6="libc6.1"; fi
17
18     required="$(get_debs Priority: required)"
19
20     if doing_variant -; then 
21       #required="$required $(get_debs Priority: important)"
22       #  ^^ should be getting debconf here somehow maybe
23       base="$(get_debs Priority: important)"
24     elif doing_variant buildd; then
25       # TODO: add Build-Essential: yes extraoverrides
26       #base="$(get_debs Build-Essential: yes)"
27
28       add () { if [ "$ARCH" = "$1" ]; then eval "$2=\"\$$2 $3\""; fi; }
29
30       base="apt binutils cpio cpp cpp-4.0 dpkg-dev g++ g++-4.0 gcc gcc-4.0 ${LIBC6}-dev libgdbm3 libstdc++6 libstdc++6-4.0-dev linux-kernel-headers make patch perl perl-modules"
31
32       add ia64 base "libunwind7-dev"
33       add sparc base "lib64gcc1"
34       add sparc base "libc6-dev-sparc64"
35       add sparc base "libc6-sparc64"
36     fi
37 }
38
39 first_stage_install () {
40     extract $required
41
42     mkdir -p "$TARGET/var/lib/dpkg"
43     : >"$TARGET/var/lib/dpkg/status"
44     : >"$TARGET/var/lib/dpkg/available"
45
46     setup_etc
47     if [ ! -e "$TARGET/etc/fstab" ]; then
48         echo '# UNCONFIGURED FSTAB FOR BASE SYSTEM' > "$TARGET/etc/fstab"
49         chown 0.0 "$TARGET/etc/fstab"; chmod 644 "$TARGET/etc/fstab"
50     fi
51
52     setup_devices
53
54     x_feign_install () {
55         local pkg="$1"
56         local deb="$(debfor $pkg)"
57         local ver="$(
58             ar -p "$TARGET/$deb" control.tar.gz | zcat |
59                 tar -O -xf - control ./control 2>/dev/null |
60                 sed -ne 's/^Version: *//Ip' | head -n 1
61         )"
62
63         mkdir -p "$TARGET/var/lib/dpkg/info"
64
65         echo \
66 "Package: $pkg
67 Version: $ver
68 Status: install ok installed" >> "$TARGET/var/lib/dpkg/status"
69
70         touch "$TARGET/var/lib/dpkg/info/${pkg}.list"
71     }
72
73     x_feign_install dpkg
74 }
75
76 second_stage_install () {
77     x_core_install () {
78         smallyes '' | in_target dpkg --force-depends --install $(debfor "$@")
79     }
80
81     p () {
82         baseprog="$(($baseprog + ${1:-1}))"
83     }
84
85     setup_proc
86     in_target /sbin/ldconfig
87
88     DEBIAN_FRONTEND=noninteractive
89     DEBCONF_NONINTERACTIVE_SEEN=true
90     export DEBIAN_FRONTEND DEBCONF_NONINTERACTIVE_SEEN
91
92     baseprog=0
93     bases=7
94
95     p; progress $baseprog $bases INSTCORE "Installing core packages" #1
96     info INSTCORE "Installing core packages..."
97
98     p; progress $baseprog $bases INSTCORE "Installing core packages" #2
99     ln -sf mawk $TARGET/usr/bin/awk
100     x_core_install base-files base-passwd
101     p; progress $baseprog $bases INSTCORE "Installing core packages" #3
102     x_core_install dpkg
103
104     if [ ! -e "$TARGET/etc/localtime" ]; then
105         ln -sf /usr/share/zoneinfo/UTC "$TARGET/etc/localtime"
106     fi
107
108     p; progress $baseprog $bases INSTCORE "Installing core packages" #4
109     x_core_install $LIBC6
110
111     p; progress $baseprog $bases INSTCORE "Installing core packages" #5
112     x_core_install perl-base
113
114     p; progress $baseprog $bases INSTCORE "Installing core packages" #6
115     rm $TARGET/usr/bin/awk
116     x_core_install mawk
117
118     p; progress $baseprog $bases INSTCORE "Installing core packages" #7
119     if doing_variant -; then
120       x_core_install debconf
121     fi
122
123     baseprog=0
124     bases=$(set -- $required; echo $#)
125
126     info UNPACKREQ "Unpacking required packages..."
127
128     smallyes '' | 
129       (repeat 5 in_target_failmsg UNPACK_REQ_FAIL_FIVE "Failure while unpacking required packages.  This will be attempted up to five times." "" \
130       dpkg --status-fd 8 --force-depends --unpack $(debfor $required) 8>&1 1>&7 |
131       dpkg_progress $baseprog $bases UNPACKREQ "Unpacking required packages" UNPACKING) 7>&1
132
133     info CONFREQ "Configuring required packages..."
134
135     mv "$TARGET/sbin/start-stop-daemon" "$TARGET/sbin/start-stop-daemon.REAL"
136     echo \
137 "#!/bin/sh
138 echo
139 echo \"Warning: Fake start-stop-daemon called, doing nothing\"" > "$TARGET/sbin/start-stop-daemon"
140     chmod 755 "$TARGET/sbin/start-stop-daemon"
141
142     setup_dselect_method apt
143
144     smallyes '' | 
145       (in_target_failmsg CONF_REQ_FAIL "Failure while configuring required packages." "" \
146       dpkg --status-fd 8 --configure --pending --force-configure-any --force-depends 8>&1 1>&7 |
147       dpkg_progress $baseprog $bases CONFREQ "Configuring required packages" CONFIGURING) 7>&1
148
149     baseprog=0
150     bases="$(set -- $base; echo $#)"
151
152     info UNPACKBASE "Unpacking the base system..."
153
154     smallyes '' | 
155       (repeat 5 in_target_failmsg INST_BASE_FAIL_FIVE "Failure while installing base packages.  This will be re-attempted up to five times." "" \
156       dpkg --status-fd 8 --force-auto-select --force-overwrite --force-confold --skip-same-version --unpack $(debfor $base) 8>&1 1>&7 |
157       dpkg_progress $baseprog $bases UNPACKBASE "Unpacking base system" UNPACKING) 7>&1
158
159     info CONFBASE "Configuring the base system..."
160
161     smallyes '' |
162       (repeat 5 in_target_failmsg CONF_BASE_FAIL_FIVE "Failure while configuring base packages.  This will be attempted 5 times." "" \
163       dpkg --status-fd 8 --force-confold --skip-same-version --configure -a 8>&1 1>&7 |
164       dpkg_progress $baseprog $bases CONFBASE "Configuring base system" CONFIGURING) 7>&1
165
166     mv "$TARGET/sbin/start-stop-daemon.REAL" "$TARGET/sbin/start-stop-daemon"
167
168     progress $bases $bases CONFBASE "Configuring base system"
169     info BASESUCCESS "Base system installed successfully."
170 }