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