3 # (C) Copyright 2009 Red Hat Inc.
5 # This program is free software; you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 2 of the License, or
8 # (at your option) any later version.
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software
17 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 # Written by Richard W.M. Jones <rjones@redhat.com>
23 --long groupinstall:,group-install:,help,install:,noclean,no-clean \
24 -n febootstrap -- "$@"`
26 echo "febootstrap: problem parsing the command line arguments"
39 echo "Usage: febootstrap [--options] REPO TARGET [MIRROR]"
40 echo "Please read febootstrap(8) man page for more information."
48 --groupinstall|--group-install)
61 echo "Internal error!"
66 if [ $# -lt 2 -o $# -gt 3 ]; then
75 # Architecture is currently always the same as the current arch. We
76 # cannot do --foreign builds. See discussion in the manpage.
79 # Create a temporary directory, make sure it gets cleaned up at the end.
84 rm -rf "$tmpdir" && exit $status
86 trap remove_tmpdir EXIT
88 # Create the temporary repository configuration. The name of the
89 # repository is always 'febootstrap'.
90 cat > $tmpdir/febootstrap.repo <<__EOF__
92 name=febootstrap $repo $arch
93 failovermethod=priority
98 # "Mirror" parameter is a bit misnamed, but it means a local mirror,
99 # instead of the public Fedora mirrors.
100 if [ -n "$mirror" ]; then
101 echo "baseurl=$mirror" >> "$tmpdir"/febootstrap.repo
103 echo "mirrorlist=http://mirrors.fedoraproject.org/mirrorlist?repo=$repo&arch=$arch" >> "$tmpdir"/febootstrap.repo
106 # Create the target filesystem.
110 # Target must be an absolute path.
111 target=$(cd "$target"; pwd)
113 # This is necessary to keep yum happy. It's not clear why yum can't
114 # just create this file itself.
115 mkdir -p "$target"/var/cache/yum/febootstrap/packages
117 # NB: REQUIRED for useradd/groupadd to run properly.
119 # However this causes 'filesystem' RPM install to give the
120 # following error. Not sure how serious the error is:
121 # error: unpacking of archive failed on file /proc: cpio: utime
122 export FAKECHROOT_EXCLUDE_PATH=/proc
124 # Make the device nodes inside the fake chroot.
125 # (Copied from mock/backend.py) Why isn't there a base package which
137 mknod null c 1 3; chmod 0666 null
138 mknod full c 1 7; chmod 0666 full
139 mknod zero c 1 5; chmod 0666 zero
140 mknod random c 1 8; chmod 0666 random
141 mknod urandom c 1 9; chmod 0444 urandom
142 mknod tty c 5 0; chmod 0666 tty
143 mknod console c 5 1; chmod 0600 console
144 mknod ptmx c 5 2; chmod 0666 ptmx
145 ln -sf /proc/self/fd/0 stdin
146 ln -sf /proc/self/fd/1 stdout
147 ln -sf /proc/self/fd/2 stderr
150 export -f make_device_nodes
153 if [ $(id -u) -ne 0 ]; then
154 fakeroot -s "$target"/fakeroot.log \
164 -y -c "$tmpdir"/febootstrap.repo \
165 --disablerepo=* --enablerepo=febootstrap \
166 --noplugins --nogpgcheck \
167 --installroot="$target" \
173 if [ $(id -u) -ne 0 ]; then
174 # Bash doesn't support exporting array variables, hence this
175 # tortuous workaround.
176 fakeroot -i "$target"/fakeroot.log -s "$target"/fakeroot.log \
178 bash -c 'run_yum "$@"' run_yum "${packages[@]}"
180 run_yum "${packages[@]}"
183 # Clean up the yum repository.
184 if [ "$clean" = "yes" ]; then
185 rm -rf "$target"/var/cache/yum/febootstrap