mirror of
				https://git.launchpad.net/livecd-rootfs
				synced 2025-10-22 20:44:08 +00:00 
			
		
		
		
	Merge from trunk
This commit is contained in:
		
						commit
						1847abe879
					
				
							
								
								
									
										19
									
								
								BuildLiveCD
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								BuildLiveCD
									
									
									
									
									
								
							| @ -27,7 +27,6 @@ if [ -n "$SSH_ORIGINAL_COMMAND" ]; then | |||||||
| fi | fi | ||||||
| ARCH=$(dpkg --print-architecture) | ARCH=$(dpkg --print-architecture) | ||||||
| SUBARCH="" | SUBARCH="" | ||||||
| SUBARCHARG="" |  | ||||||
| NEWSUITE="precise" | NEWSUITE="precise" | ||||||
| SUITES="" | SUITES="" | ||||||
| PROPOSED="" | PROPOSED="" | ||||||
| @ -35,24 +34,19 @@ IMAGEFORMAT="" | |||||||
| LIVE_BUILD=false | LIVE_BUILD=false | ||||||
| UBUNTU_DEFAULTS_LOCALE="" | UBUNTU_DEFAULTS_LOCALE="" | ||||||
| 
 | 
 | ||||||
| while getopts :A:s:r:d:f:pa:lu:t: name; do case $name in | while getopts :A:s:r:d:f:plu:t: name; do case $name in | ||||||
|     A)	ARCH="$OPTARG";; |     A)	ARCH="$OPTARG";; | ||||||
|     s)	SUBARCH="$OPTARG";; |     s)	SUBARCH="$OPTARG";; | ||||||
|     r)	SUBPROJECT="$OPTARG";; |     r)	SUBPROJECT="$OPTARG";; | ||||||
|     d)	NEWSUITE="$OPTARG";; |     d)	NEWSUITE="$OPTARG";; | ||||||
|     f)	IMAGEFORMAT="$OPTARG";; |     f)	IMAGEFORMAT="$OPTARG";; | ||||||
|     p)	PROPOSED="-p";; |     p)	PROPOSED="-p";; | ||||||
|     a)	APT_SOURCE="-A $OPTARG";; |  | ||||||
|     l)	LIVE_BUILD=:;; |     l)	LIVE_BUILD=:;; | ||||||
|     u)	UBUNTU_DEFAULTS_LOCALE="$OPTARG";; |     u)	UBUNTU_DEFAULTS_LOCALE="$OPTARG";; | ||||||
|     t)	UBUNTU_TOUCH_ANDROID="$OPTARG";; |     t)	UBUNTU_TOUCH_ANDROID="$OPTARG";; | ||||||
| esac; done; | esac; done; | ||||||
| shift $((OPTIND-1)) | shift $((OPTIND-1)) | ||||||
| 
 | 
 | ||||||
| if [ -n "$SUBARCH" ]; then |  | ||||||
|     SUBARCHARG="-s$SUBARCH" |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| for s in $NEWSUITE; do | for s in $NEWSUITE; do | ||||||
|     if [ -d build-${s}-live/chroot-${s} ]; then SUITES="$SUITES $s"; fi |     if [ -d build-${s}-live/chroot-${s} ]; then SUITES="$SUITES $s"; fi | ||||||
| done | done | ||||||
| @ -62,11 +56,9 @@ fi | |||||||
| for s in $SUITES; do | for s in $SUITES; do | ||||||
|     case $s in |     case $s in | ||||||
|         dapper|edgy|feisty|gutsy|hardy) |         dapper|edgy|feisty|gutsy|hardy) | ||||||
|             ARCHARG="" |  | ||||||
|             old_suite="yes" |             old_suite="yes" | ||||||
|             ;; |             ;; | ||||||
|         *) |         *) | ||||||
|             ARCHARG="-a$ARCH" |  | ||||||
|             new_suite="yes" |             new_suite="yes" | ||||||
|             ;; |             ;; | ||||||
|     esac |     esac | ||||||
| @ -108,7 +100,7 @@ for STE in $SUITES; do | |||||||
|     if [ -d ~/build-${STE}-live/chroot-${STE} ]; then |     if [ -d ~/build-${STE}-live/chroot-${STE} ]; then | ||||||
| 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -qq update || true | 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -qq update || true | ||||||
| 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -y dist-upgrade || true | 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -y dist-upgrade || true | ||||||
| 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -y install livecd-rootfs || true | 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -y install livecd-rootfs eatmydata || true | ||||||
| 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -y --install-recommends install ubuntu-defaults-builder || true | 	sudo chroot ~/build-${STE}-live/chroot-${STE} apt-get -y --install-recommends install ubuntu-defaults-builder || true | ||||||
|     fi |     fi | ||||||
| done | done | ||||||
| @ -144,12 +136,11 @@ for STE in $SUITES; do | |||||||
| 	COMMAND="PROJECT=${FS} SUBPROJECT=${SUBPROJECT} ARCH=${ARCH} SUBARCH=${SUBARCH} lb build" | 	COMMAND="PROJECT=${FS} SUBPROJECT=${SUBPROJECT} ARCH=${ARCH} SUBARCH=${SUBARCH} lb build" | ||||||
|     elif [ "$UBUNTU_DEFAULTS_LOCALE" ]; then |     elif [ "$UBUNTU_DEFAULTS_LOCALE" ]; then | ||||||
| 	COMMAND="ubuntu-defaults-image --locale ${UBUNTU_DEFAULTS_LOCALE} --arch ${ARCH} --release ${STE}" | 	COMMAND="ubuntu-defaults-image --locale ${UBUNTU_DEFAULTS_LOCALE} --arch ${ARCH} --release ${STE}" | ||||||
|     elif [ "$UBUNTU_TOUCH_ANDROID" ]; then |  | ||||||
| 	COMMAND="/usr/sbin/ubuntu-touch-android.sh ${SUBARCH}" |  | ||||||
|     else |     else | ||||||
| 	COMMAND="/usr/sbin/livecd.sh ${SUBARCHARG} ${APT_SOURCE} ${PROPOSED} -d${STE} ${IMAGEFORMAT:+-f$IMAGEFORMAT} ${ARCHARG} ${IMAGEARG} ${FS}" | 	echo "Must pass either -l or -u." | ||||||
|  | 	exit 1 | ||||||
|     fi |     fi | ||||||
|     if $LINUX32 sudo chroot ${DIR%/./*} sh -c "cd /${DIR#*/./} && $COMMAND" >> ${LOG} 2>&1; then |     if $LINUX32 sudo chroot ${DIR%/./*} sh -c "cd /${DIR#*/./} && eatmydata -- $COMMAND" >> ${LOG} 2>&1; then | ||||||
| 	rm -f ${PUBDIR}current | 	rm -f ${PUBDIR}current | ||||||
| 	ln -sf ${NOW} ${PUBDIR}current | 	ln -sf ${NOW} ${PUBDIR}current | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										72
									
								
								debian/changelog
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										72
									
								
								debian/changelog
									
									
									
									
										vendored
									
									
								
							| @ -1,3 +1,75 @@ | |||||||
|  | livecd-rootfs (2.167) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * make sure FLASH_KERNEL_SKIP is set when we post-process touch images | ||||||
|  | 
 | ||||||
|  |  -- Oliver Grawert <ogra@ubuntu.com>  Wed, 31 Jul 2013 13:33:53 +0200 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.166) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * add radio user (with UID 1001 (required by android)) to the default user | ||||||
|  |     creation for ubuntu-touch | ||||||
|  | 
 | ||||||
|  |  -- Oliver Grawert <ogra@ubuntu.com>  Thu, 25 Jul 2013 11:14:34 +0200 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.165) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * Remove e2fs-zero.py and references to it, it's no longer used. | ||||||
|  | 
 | ||||||
|  |  -- Adam Conrad <adconrad@ubuntu.com>  Wed, 24 Jul 2013 11:42:23 +0100 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.164) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * Run builds under eatmydata.  (This doesn't actually seem to help very | ||||||
|  |     much - it shaves a minute off a 48-minute test build on my laptop - but | ||||||
|  |     it will stop people being distracted by it.) | ||||||
|  |   * Remove livecd.py, which was never finished. | ||||||
|  |   * Remove all vestiges of livecd.sh and ubuntu-touch-android.sh. | ||||||
|  |     Requiescant in pace. | ||||||
|  |   * Temporarily disable Click package installation, until desktop/AppArmor | ||||||
|  |     integration has landed properly. | ||||||
|  | 
 | ||||||
|  |  -- Colin Watson <cjwatson@ubuntu.com>  Tue, 23 Jul 2013 23:21:56 +0100 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.163) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * point click package install to http://archive-team.internal/click_packages | ||||||
|  | 
 | ||||||
|  |  -- Oliver Grawert <ogra@ubuntu.com>  Thu, 18 Jul 2013 16:31:54 +0200 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.162) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * Ubuntu Touch click package install hook. | ||||||
|  | 
 | ||||||
|  |  -- Sergio Schvezov <sergio.schvezov@canonical.com>  Wed, 17 Jul 2013 00:05:49 -0300 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.161) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * drop bashrc mangling from ubuntu-touch builds \o/ | ||||||
|  | 
 | ||||||
|  |  -- Oliver Grawert <ogra@ubuntu.com>  Wed, 17 Jul 2013 16:30:12 +0200 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.160) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * Do the same trick as in 2.158 for kubuntu armhf+omap4 too. | ||||||
|  | 
 | ||||||
|  |  -- Iain Lane <iain.lane@canonical.com>  Wed, 17 Jul 2013 11:52:23 +0100 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.159) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * make touch images source the dbus session address from | ||||||
|  |     ~/.cache/upstart/dbus-session instead of ~/.dbus-session | ||||||
|  | 
 | ||||||
|  |  -- Oliver Grawert <ogra@ubuntu.com>  Tue, 16 Jul 2013 20:12:31 +0200 | ||||||
|  | 
 | ||||||
|  | livecd-rootfs (2.158) saucy; urgency=low | ||||||
|  | 
 | ||||||
|  |   * Under armhf+omap4, don't use the ubuntu-desktop Task, but use the | ||||||
|  |     metapackage instead. The metapackage doesn't pull in the X stack which | ||||||
|  |     allows us to additionally install the special "revert" X stack that we | ||||||
|  |     require here. | ||||||
|  | 
 | ||||||
|  |  -- Iain Lane <iain.lane@canonical.com>  Tue, 16 Jul 2013 17:19:22 +0100 | ||||||
|  | 
 | ||||||
| livecd-rootfs (2.157) saucy; urgency=low | livecd-rootfs (2.157) saucy; urgency=low | ||||||
| 
 | 
 | ||||||
|   * add xserver-xorg-input-evdev-omap-revert and |   * add xserver-xorg-input-evdev-omap-revert and | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								debian/copyright
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								debian/copyright
									
									
									
									
										vendored
									
									
								
							| @ -1,5 +1,4 @@ | |||||||
| livecd.sh is copyright (c) 2004-2007 by Canonical Ltd. | live-build/* is copyright (c) 2004-2013 by Canonical Ltd. | ||||||
| e2fs-zero.py is copyright (c) 2005 by Paul Sladen |  | ||||||
| 
 | 
 | ||||||
| These programs are free software; you can redistribute and/or modify | These programs are free software; you can redistribute and/or modify | ||||||
| them under the terms of the GNU General Public License as published by | them under the terms of the GNU General Public License as published by | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								debian/install
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								debian/install
									
									
									
									
										vendored
									
									
								
							| @ -1,2 +1 @@ | |||||||
| livecd.sh e2fs-zero.py usr/sbin |  | ||||||
| live-build usr/share/livecd-rootfs | live-build usr/share/livecd-rootfs | ||||||
|  | |||||||
							
								
								
									
										235
									
								
								e2fs-zero.py
									
									
									
									
									
								
							
							
						
						
									
										235
									
								
								e2fs-zero.py
									
									
									
									
									
								
							| @ -1,235 +0,0 @@ | |||||||
| #!/usr/bin/env python |  | ||||||
| # Copyright Paul Sladen <code@paul.sladen.org>, 2005-05-14 |  | ||||||
| # You may use this work under the terms of the GNU GPL. |  | ||||||
| # |  | ||||||
| # Synopsis: |  | ||||||
| # 1.  call dumpe2fs /dev/xxxx | grep -E '^(  Free blocks: |Block size:)' |  | ||||||
| # 2.  decode Block size, eg. 4096 bytes |  | ||||||
| # 3.  decode ranges of Free blocks, like:   123, 132-145, 149-150, 167 |  | ||||||
| # 4.  open '/dev/xxxx' for writing |  | ||||||
| # 5.  seek to each location (block_number * block_size) and write lots of NUL |  | ||||||
| # 6.  profit |  | ||||||
| 
 |  | ||||||
| """\ |  | ||||||
| e2fszero 0.1 (2005-05-14) |  | ||||||
| Usage: e2fs-zero [-h] [-v] [-w|-n] ext2-filesystem |  | ||||||
| Zero unused blocks in an Ext2 Filesystem, to increase compression and rsyncability. |  | ||||||
|   -h --help      this message |  | ||||||
|   -v --verbose   extra information |  | ||||||
|   -n --dryrun    disable writing to the filesystem |  | ||||||
|   -w --write     enable writing to the filesystem (default) |  | ||||||
| Note: This program relies on 'dumpe2fs' to do the dangerous calculations! |  | ||||||
| NOTE: YES, THIS PROGRAM REALLY WILL OVERWRITE (bits of) YOUR FILESYSTEM WITH NULLS\ |  | ||||||
| """ |  | ||||||
| DUMPE2FS = '/sbin/dumpe2fs' |  | ||||||
| import os, sys |  | ||||||
| 
 |  | ||||||
| # messages |  | ||||||
| verbose = False |  | ||||||
| # enable writing operations |  | ||||||
| dangerous = False |  | ||||||
| 
 |  | ||||||
| def main(): |  | ||||||
|     global verbose, dangerous, DUMPE2FS |  | ||||||
| 
 |  | ||||||
|     # catch people who need usage help |  | ||||||
|     # this is the worst and more incorrect piece of code in here |  | ||||||
| 
 |  | ||||||
|     leftover = [] |  | ||||||
|     for fight in sys.argv[1:]: |  | ||||||
|         if fight == '-v' or fight == '--verbose': |  | ||||||
|             verbose = True |  | ||||||
|             continue |  | ||||||
|         elif fight == '-n' or fight == '--dryrun': |  | ||||||
|             dangerous = False |  | ||||||
|             continue |  | ||||||
|         elif fight == '-w' or fight == '--write': |  | ||||||
|             dangerous = True |  | ||||||
|             continue |  | ||||||
|         elif fight[0] == '-': |  | ||||||
|             print __doc__ |  | ||||||
|             sys.exit() |  | ||||||
|         leftover.append(fight) |  | ||||||
| 
 |  | ||||||
|     #print `leftover` |  | ||||||
| 
 |  | ||||||
|     try: |  | ||||||
|         if len(leftover) != 1: |  | ||||||
|             raise 'ArgumentError' |  | ||||||
|         filesystem = leftover[0] |  | ||||||
|         if len(filesystem) <= 0:  |  | ||||||
|             raise 'NoFilesystemName' |  | ||||||
|     except: |  | ||||||
|         print >> sys.stderr, __doc__ |  | ||||||
|         sys.exit() |  | ||||||
| 
 |  | ||||||
|     # We need access to the filesystem image (either a block device or a very large file) |  | ||||||
|     # and we also need to have 'dumpe2fs', otherwise we can't open a pipe() from it. |  | ||||||
|      |  | ||||||
|     try: |  | ||||||
|         stat = os.stat(filesystem) |  | ||||||
|         stat = os.stat(DUMPE2FS) |  | ||||||
|         # Might aswell just let the user see any stderr errors from dumpe2fs, |  | ||||||
|         # although annoying it prints a banner first |  | ||||||
|         #out, err = os.popen3("%s '%s'" % (DUMPE2FS, filesystem))[1:] |  | ||||||
|         sys.stderr.write('calling ') |  | ||||||
|         pipe = os.popen("%s '%s'" % (DUMPE2FS, filesystem)) |  | ||||||
|     except OSError: |  | ||||||
|         print >> sys.stderr, "$(PROGRAM): can't access $(filesystem), try --help" |  | ||||||
| 
 |  | ||||||
|     # We're looking for the following lines from dumpe2fs, in order, and ignoring the rest: |  | ||||||
|     #   Filesystem volume name:   <none> |  | ||||||
|     #   Free blocks:              134859 |  | ||||||
|     #   Block size:               4096 |  | ||||||
|     #     Free blocks:            1123, 1345-1456, 1567, 1678-1789 |  | ||||||
|     #     Free blocks:            2123-2345, 2456-2567, 2678, 2789 |  | ||||||
| 
 |  | ||||||
|     s = pipe.readline() |  | ||||||
|     if s <= 'Filesystem volume name:': |  | ||||||
|         raise "Failed to parse correct dumpe2fs output" |  | ||||||
| 
 |  | ||||||
|     # 'Free blocks:' |  | ||||||
|     while not s.startswith('Free blocks:') and len(s) > 0: |  | ||||||
|         s = pipe.readline() |  | ||||||
|     try:  |  | ||||||
|         free_blocks = int(s.strip().split(': ')[1]) |  | ||||||
|     except: |  | ||||||
|         raise "Failed to parse unused block count ('Free blocks:')" |  | ||||||
|     if verbose: |  | ||||||
|         print "Detected filsystem contains %d free blocks" % (free_blocks) |  | ||||||
| 
 |  | ||||||
|     # 'Block size:' |  | ||||||
|     while not s.startswith('Block size:') and len(s) > 0: |  | ||||||
|         s = pipe.readline() |  | ||||||
|     try:  |  | ||||||
|         block_size = int(s.strip().split(': ')[1]) |  | ||||||
|     except: |  | ||||||
|         raise "Failed to parse filesystem block-size ('Block size:')" |  | ||||||
|     if verbose: |  | ||||||
|         print "Detected filsystem block_size = %d bytes" % (block_size) |  | ||||||
| 
 |  | ||||||
|     # 'Free blocks:' (multiple entries, one per Ext2 "group") |  | ||||||
|     free_ranges = [] |  | ||||||
|     while True: |  | ||||||
|         while len(s) and not s.startswith('  Free blocks:'): |  | ||||||
|             try: |  | ||||||
|                 s = pipe.readline() |  | ||||||
|             except: |  | ||||||
|                 raise "failed to read" |  | ||||||
|         # Detect EOF |  | ||||||
|         if not len(s): |  | ||||||
|             break |  | ||||||
|         #print len(s), `s` |  | ||||||
|         # Strip the label: and separate the commas |  | ||||||
|         try: |  | ||||||
|             #print `s.strip()` |  | ||||||
|             free_ranges += s.split(': ', 1)[1].strip().split(', ')[:] |  | ||||||
|         except: |  | ||||||
|             print >> sys.stderr, `s` |  | ||||||
|             raise "Failed to parse free_ranges ('  Free blocks:')" |  | ||||||
|         s = pipe.readline() |  | ||||||
|     #print `free_ranges` |  | ||||||
| 
 |  | ||||||
|     # Turn the strings into integer lists of useful free blocks |  | ||||||
|     # 'blocks' contains each free blocks and get _very_ big |  | ||||||
|     # 'wipes' contains [offset, length] pairs |  | ||||||
|     record_blocks = False |  | ||||||
|     record_wipes = True |  | ||||||
|     blocks = [] |  | ||||||
|     wipes = [] |  | ||||||
|     free_block_count = 0 |  | ||||||
| 
 |  | ||||||
|     for egg in free_ranges: |  | ||||||
|         if len(egg) > 0: |  | ||||||
|             # Assuming this ext2 group has some spare space in it... |  | ||||||
|             try: |  | ||||||
|                 # Find some ranges (Ranges are inclusive, eg.  172-184) |  | ||||||
|                 if egg.find('-') > 0: |  | ||||||
|                     #blocks += range(*map(int, egg.split('-'))) |  | ||||||
|                     a, b = egg.split('-') |  | ||||||
|                     if record_blocks: blocks += range(int(a), int(b) + 1) |  | ||||||
|                     if record_wipes: wipes.append([block_size * int(a), block_size * (int(b) - int(a) + 1)]) |  | ||||||
|                     free_block_count += int(b) - int(a) + 1 |  | ||||||
|                 # But some are singular (eg.  '199') is just one free block on its own |  | ||||||
|                 else: |  | ||||||
|                     if record_blocks: blocks += [int(egg)] |  | ||||||
|                     if record_wipes: wipes.append([block_size * int(egg), block_size]) |  | ||||||
|                     free_block_count += 1 |  | ||||||
|             except: |  | ||||||
|                 # since we're nearly at the point of writing to the disk, |  | ||||||
|                 # it probably better to just safely roll over and die |  | ||||||
|                 print "Bzzzz on trying to decode " + `egg` |  | ||||||
|     blocks.sort() |  | ||||||
|     #print len(blocks), `blocks` |  | ||||||
|     if verbose: |  | ||||||
|         print len(wipes), 'offset/length pairs', `wipes` |  | ||||||
|     if verbose or free_blocks != free_block_count: |  | ||||||
|         print "Free blocks; parsed: %d, decoded: %d" % (free_blocks, free_block_count) |  | ||||||
|     if free_blocks != free_block_count: |  | ||||||
|         raise 'Decoded Free blocks do not match count in filesystem!' |  | ||||||
|     perform_wipe(filesystem, wipes) |  | ||||||
| 
 |  | ||||||
| WRITE_SIZE = 2**18 |  | ||||||
| PADDING = '\0' |  | ||||||
| 
 |  | ||||||
| # fstream file-access [open/f.write/f.tell] seems to have some |  | ||||||
| # grave funnyiness that causes the file to be randomly truncated. |  | ||||||
| # Since I spent a good while tearing my hair out over this, I've |  | ||||||
| # changed it to just use the normal POSIX os.open/os.write/close |  | ||||||
| 
 |  | ||||||
| # Here we take the offset/length pairs decoded above, open the |  | ||||||
| # ext2 filesystem image and overwrite the unused areas. |  | ||||||
| # it would be handy to truncate areas (make them sparse) so that they |  | ||||||
| # don't actually take up space on disk to... |  | ||||||
| 
 |  | ||||||
| def perform_wipe(filename, wipes = [[0, 0]]): |  | ||||||
|     progress_counter = 0.0 |  | ||||||
|     percentage = 100.0 / len(wipes) |  | ||||||
|     empty_space = PADDING * WRITE_SIZE |  | ||||||
| 
 |  | ||||||
|     #f = open(filename, 'w') |  | ||||||
|     if dangerous: |  | ||||||
|         mode = os.O_WRONLY|os.EX_CANTCREAT |  | ||||||
|     else: |  | ||||||
|         mode = os.O_RDONLY|os.EX_CANTCREAT |  | ||||||
|     fd = os.open(filename, mode) |  | ||||||
| 
 |  | ||||||
|     # Don't waste space on a tty, display a progress percentage instead. |  | ||||||
|     if sys.stdout.isatty(): |  | ||||||
|         end = '\r' |  | ||||||
|     else: |  | ||||||
|         end = '\n' |  | ||||||
|     for offset, length in wipes: |  | ||||||
|         progress_counter += percentage |  | ||||||
|         sys.stdout.write("wiping position %16d for %16d bytes  (%5.1f%%)%s" % |  | ||||||
|                          (offset, length, progress_counter, end)) |  | ||||||
|         #f.seek(offset) |  | ||||||
|         os.lseek(fd, offset, 0) |  | ||||||
|         #print 'currently at (before) ' + `f.tell()` |  | ||||||
|         #print 'currently at (before) ' + `os.tell(fd)` |  | ||||||
|         # only write 256kB at a time, since we can stick that in a buffer |  | ||||||
|         # and not have Python regenerate HUGE arrays each time |  | ||||||
|         if 1: |  | ||||||
|             while length >= WRITE_SIZE and length > 0: |  | ||||||
|                 #f.write(empty_space) |  | ||||||
|                 #length -= WRITE_SIZE |  | ||||||
|                 if dangerous: |  | ||||||
|                     length -= os.write(fd, empty_space) |  | ||||||
|                 else: |  | ||||||
|                     length -= WRITE_SIZE |  | ||||||
|         #f.write('\xaa' * length) |  | ||||||
|         #f.write('hello') |  | ||||||
|         if dangerous: |  | ||||||
|             os.write(fd, PADDING * length) |  | ||||||
|         #print 'currently at (after)  ' + `f.tell()` |  | ||||||
|         #print 'currently at (after)  ' + `os.tell(fd)` |  | ||||||
|     #f.close() |  | ||||||
|     os.close(fd) |  | ||||||
|     if sys.stdout.isatty(): |  | ||||||
|         print |  | ||||||
|     if verbose: |  | ||||||
|         print 'All done!  Hopefully your filesystem is not toast.' |  | ||||||
| 
 |  | ||||||
| if __name__ == '__main__': |  | ||||||
|     main() |  | ||||||
| 
 |  | ||||||
| @ -414,6 +414,8 @@ if [ "$PROJECT" = "ubuntu-touch" ] && [ "$ARCH" = "armhf" ]; then | |||||||
| 
 | 
 | ||||||
| 	sourceslist="chroot/etc/apt/sources.list" | 	sourceslist="chroot/etc/apt/sources.list" | ||||||
| 
 | 
 | ||||||
|  | 	export FLASH_KERNEL_SKIP=True | ||||||
|  | 
 | ||||||
| 	lb chroot_proc install "$@" | 	lb chroot_proc install "$@" | ||||||
| 	lb chroot_sysfs install "$@" | 	lb chroot_sysfs install "$@" | ||||||
| 	lb chroot_devpts install "$@" | 	lb chroot_devpts install "$@" | ||||||
|  | |||||||
| @ -172,12 +172,40 @@ esac | |||||||
| 
 | 
 | ||||||
| case $PROJECT in | case $PROJECT in | ||||||
| 	ubuntu|ubuntu-dvd) | 	ubuntu|ubuntu-dvd) | ||||||
| 		add_task install minimal standard ubuntu-desktop | 		add_task install minimal standard | ||||||
|  | 		case "$ARCH+$SUBARCH" in | ||||||
|  | 			armhf+omap4) | ||||||
|  | 				# Don't use the task as this drags in the regular X | ||||||
|  | 				# stack (the metapackage doesn't). We want the | ||||||
|  | 				# "reverted" one. | ||||||
|  | 				add_package install ubuntu-desktop \ | ||||||
|  | 					xserver-xorg-core-omap-revert \ | ||||||
|  | 					xserver-xorg-video-omap-revert \ | ||||||
|  | 					xserver-xorg-input-evdev-omap-revert  | ||||||
|  | 				;; | ||||||
|  | 			*) | ||||||
|  | 				add_task install ubuntu-desktop | ||||||
|  | 				;; | ||||||
|  | 		esac | ||||||
| 		LIVE_TASK='ubuntu-live' | 		LIVE_TASK='ubuntu-live' | ||||||
| 		;; | 		;; | ||||||
| 
 | 
 | ||||||
| 	kubuntu|kubuntu-dvd) | 	kubuntu|kubuntu-dvd) | ||||||
| 		add_task install minimal standard kubuntu-desktop | 		add_task install minimal standard | ||||||
|  | 		case "$ARCH+$SUBARCH" in | ||||||
|  | 			armhf+omap4) | ||||||
|  | 				# Don't use the task as this drags in the regular X | ||||||
|  | 				# stack (the metapackage doesn't). We want the | ||||||
|  | 				# "reverted" one. | ||||||
|  | 				add_package install kubuntu-desktop \ | ||||||
|  | 					xserver-xorg-core-omap-revert \ | ||||||
|  | 					xserver-xorg-video-omap-revert \ | ||||||
|  | 					xserver-xorg-input-evdev-omap-revert  | ||||||
|  | 				;; | ||||||
|  | 			*) | ||||||
|  | 				add_task install kubuntu-desktop | ||||||
|  | 				;; | ||||||
|  | 		esac | ||||||
| 		LIVE_TASK='kubuntu-live' | 		LIVE_TASK='kubuntu-live' | ||||||
| 		COMPONENTS='main restricted universe' | 		COMPONENTS='main restricted universe' | ||||||
| 		add_chroot_hook remove-gnome-icon-cache | 		add_chroot_hook remove-gnome-icon-cache | ||||||
| @ -316,7 +344,7 @@ case $ARCH in | |||||||
| 						add_package install u-boot-linaro-omap4-panda u-boot-tools | 						add_package install u-boot-linaro-omap4-panda u-boot-tools | ||||||
| 						;; | 						;; | ||||||
| 					*) | 					*) | ||||||
| 						add_package install u-boot-linaro-omap4-panda u-boot-tools pvr-omap4 xserver-xorg-video-omap-revert xserver-xorg-input-evdev-omap-revert | 						add_package install u-boot-linaro-omap4-panda u-boot-tools pvr-omap4 | ||||||
| 						;; | 						;; | ||||||
| 				esac | 				esac | ||||||
| 				BINARY_REMOVE_LINUX=false | 				BINARY_REMOVE_LINUX=false | ||||||
|  | |||||||
| @ -10,6 +10,7 @@ echo "I: set user $USER password to $USER" | |||||||
| echo "$USER:$USER" | chpasswd | echo "$USER:$USER" | chpasswd | ||||||
| 
 | 
 | ||||||
| adduser --gecos system --no-create-home --disabled-login --disabled-password system --uid 1000 | adduser --gecos system --no-create-home --disabled-login --disabled-password system --uid 1000 | ||||||
|  | adduser --gecos radio --no-create-home --disabled-login --disabled-password radio --uid 1001 | ||||||
| 
 | 
 | ||||||
| # Prevent the system user from being presented in the greeter by bumping MIN_UID | # Prevent the system user from being presented in the greeter by bumping MIN_UID | ||||||
| sed -i 's/^\(UID_MIN\s\+\).*/\11001/g' /etc/login.defs | sed -i 's/^\(UID_MIN\s\+\).*/\11001/g' /etc/login.defs | ||||||
|  | |||||||
| @ -26,7 +26,3 @@ LANGUAGE=en_US:en | |||||||
| QT_IM_MODULE=maliitphablet | QT_IM_MODULE=maliitphablet | ||||||
| HUD_NO_STORE_USAGE_DATA=1 | HUD_NO_STORE_USAGE_DATA=1 | ||||||
| INDICATOR_ALLOW_NO_WATCHERS=1" > /etc/environment | INDICATOR_ALLOW_NO_WATCHERS=1" > /etc/environment | ||||||
| 
 |  | ||||||
| echo -e "\n# export the phablet shell dbus session on normal login shells |  | ||||||
| source /home/phablet/.dbus-session |  | ||||||
| export DBUS_SESSION_BUS_ADDRESS" >> /home/phablet/.bashrc |  | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								live-build/ubuntu-touch/hooks/60-install-click.chroot
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										22
									
								
								live-build/ubuntu-touch/hooks/60-install-click.chroot
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | cat <<EOF | ||||||
|  | Click package installation temporarily disabled until desktop/AppArmor | ||||||
|  | integration is all working properly. | ||||||
|  | EOF | ||||||
|  | exit 0 | ||||||
|  | 
 | ||||||
|  | set -e | ||||||
|  | 
 | ||||||
|  | echo "Setting up click packages" | ||||||
|  | 
 | ||||||
|  | click_uri=http://archive-team.internal/click_packages | ||||||
|  | click_list=$click_uri/click_list | ||||||
|  | 
 | ||||||
|  | for package in $(wget -qO- "$click_list") | ||||||
|  | do | ||||||
|  |     echo "Setting up $package" | ||||||
|  |     wget --no-verbose -O "$package" "$click_uri"/"$package" | ||||||
|  |     click install --user=phablet --force-missing-framework "$package" | ||||||
|  |     rm "$package" | ||||||
|  | done | ||||||
							
								
								
									
										24
									
								
								livecd.py
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								livecd.py
									
									
									
									
									
								
							| @ -1,24 +0,0 @@ | |||||||
| #!/usr/bin/python |  | ||||||
| import os,sys |  | ||||||
| import atexit |  | ||||||
| 
 |  | ||||||
| class Mount: |  | ||||||
|     def __init__(self): |  | ||||||
| 	atexit.register(self.cleanup,self) |  | ||||||
| 	self.mounts={} |  | ||||||
| 	self.losetupDev=None |  | ||||||
| 
 |  | ||||||
|     def addMount(self,name): |  | ||||||
| 	self.mounts[name]=1 |  | ||||||
| 
 |  | ||||||
|     def losetup(self,name): |  | ||||||
| 	if self.losetupDev==None: |  | ||||||
| 	    self.losetupDev=os.popen("losetup -f").read().strip() |  | ||||||
| 	os.system("losetup %s %s" % (self.losetupDev,name) |  | ||||||
| 
 |  | ||||||
|     def unLosetup(self): |  | ||||||
| 	os.system("losetup -d %s"%self.losetupDev) |  | ||||||
| 
 |  | ||||||
|     def cleanup(self): |  | ||||||
| 	# XXX - need to unmount stuff |  | ||||||
| 	pass |  | ||||||
							
								
								
									
										830
									
								
								livecd.sh
									
									
									
									
									
								
							
							
						
						
									
										830
									
								
								livecd.sh
									
									
									
									
									
								
							| @ -1,830 +0,0 @@ | |||||||
| #!/bin/bash |  | ||||||
| set -eu |  | ||||||
| 
 |  | ||||||
| ########################################################################## |  | ||||||
| ####           (c) Copyright 2004-2007 Canonical Ltd.                ##### |  | ||||||
| #                                                                        # |  | ||||||
| # This program is free software; you can redistribute it and/or modify   # |  | ||||||
| # it under the terms of the GNU General Public License as published by   # |  | ||||||
| # the Free Software Foundation; either version 2, or (at your option)    # |  | ||||||
| # any later version.                                                     # |  | ||||||
| #                                                                        # |  | ||||||
| # This program is distributed in the hope that it will be useful, but    # |  | ||||||
| # WITHOUT ANY WARRANTY; without even the implied warranty of             # |  | ||||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU      # |  | ||||||
| # General Public License for more details.                               # |  | ||||||
| #                                                                        # |  | ||||||
| # You should have received a copy of the GNU General Public License with # |  | ||||||
| # your Ubuntu system, in /usr/share/common-licenses/GPL, or with the     # |  | ||||||
| # livecd-rootfs source package as the file COPYING.  If not, write to    # |  | ||||||
| # the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,   # |  | ||||||
| # Boston, MA 02110-1301 USA.                                             # |  | ||||||
| ########################################################################## |  | ||||||
| 
 |  | ||||||
| # Depends: debootstrap, rsync, python-minimal|python, procps, squashfs-tools, ltsp-server [i386], e2fsprogs |  | ||||||
| 
 |  | ||||||
| cleanup() { |  | ||||||
|     for mnt in ${ROOT}dev/pts ${ROOT}dev/shm ${ROOT}.dev ${ROOT}dev \ |  | ||||||
| 	       ${ROOT}proc/sys/fs/binfmt_misc ${ROOT}proc ${ROOT}sys \ |  | ||||||
| 	       ${ROOT}lib/modules/*/volatile ${ROOT}var/{lock,run}; do |  | ||||||
| 	umount $mnt || true |  | ||||||
|     done |  | ||||||
| 
 |  | ||||||
|     [ -n "$DEV" ] && umount $DEV && losetup -d $DEV || true |  | ||||||
|     grep ${ROOT} /proc/mounts && return 1 || return 0 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| kill_users() { |  | ||||||
|     set +e |  | ||||||
|     PIDLIST="$(ls -l /proc/*/root 2>/dev/null | grep -- " -> ${ROOT%/}" | sed -n 's/^.*proc.\([0-9]*\).*$/\1/p')" |  | ||||||
|     while [ -n "${PIDLIST}" ]; do |  | ||||||
| 	echo killing $PIDLIST |  | ||||||
| 	ps -l $(for p in $PIDLIST; do echo ' '-p $p; done) |  | ||||||
| 	kill -9 $PIDLIST |  | ||||||
| 	sleep 2 |  | ||||||
| 	PIDLIST="$(ls -l /proc/*/root 2>/dev/null | grep -- " -> ${ROOT%/}" | sed -n 's/^.*proc.\([0-9]*\).*$/\1/p')" |  | ||||||
|     done |  | ||||||
|     set -e |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| without_package() { |  | ||||||
|     echo "$2" | tr ' ' '\n' | grep -v "^$1$" | tr '\n' ' ' |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| subst_package() { |  | ||||||
|     echo "$3" | tr ' ' '\n' | sed "s/^$1$/$2/" | tr '\n' ' ' |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| livefs_squash() |  | ||||||
| { |  | ||||||
|   squashsort="http://people.ubuntu.com/~tfheen/livesort/${FSS}.list.${TARGETARCH}" |  | ||||||
|   #if wget -O livecd.${FSS}.sort ${squashsort} > /dev/null 2>&1; then |  | ||||||
|   if false; then |  | ||||||
|     echo "Using the squashfs sort list from ${squashsort}." |  | ||||||
|   else |  | ||||||
|     echo "Unable to fetch squashfs sort list; using a blank list." |  | ||||||
|     : > livecd.${FSS}.sort |  | ||||||
|   fi |  | ||||||
| 
 |  | ||||||
|   # make sure there is no old squashfs idling around |  | ||||||
|   rm -f livecd.${FSS}.squashfs |  | ||||||
| 
 |  | ||||||
|   mksquashfs ${ROOT} livecd.${FSS}.squashfs -sort livecd.${FSS}.sort |  | ||||||
|   chmod 644 livecd.${FSS}.squashfs |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| livefs_ext2() |  | ||||||
| { |  | ||||||
|   # Add 1024MiB extra free space for first boot + ext3 journal + swapfile |  | ||||||
|   size=$(($(du -ks ${ROOT} | cut -f1) + (1024000))) |  | ||||||
|   MOUNTPOINT=$(mktemp -d) |  | ||||||
|   DEV=$(losetup -f) |  | ||||||
|   echo "Building ext2 filesystem." |  | ||||||
| 
 |  | ||||||
|   # remove any stale filesystem images |  | ||||||
|   rm -f livecd.${FSS}.ext? |  | ||||||
| 
 |  | ||||||
|   # create an empty ext2 image and loop mount it |  | ||||||
|   dd if=/dev/zero of=livecd.${FSS}.ext2 bs=1024 count=0 seek=$size |  | ||||||
|   mke2fs -i 8192 -F livecd.${FSS}.ext2 |  | ||||||
|   mount -o loop=${DEV} livecd.${FSS}.ext2 ${MOUNTPOINT} |  | ||||||
| 
 |  | ||||||
|   # copy chroot content to image |  | ||||||
|   cp -a ${ROOT}/* ${MOUNTPOINT} |  | ||||||
| 
 |  | ||||||
|   # Create a swapfile in rootfs we can use or delete later on during first boot. |  | ||||||
|   # doing it *during* first boot adds 3min to the bootprocess so the decision |  | ||||||
|   # was to do it here. Luckily the file will compress to nearly zero so it does |  | ||||||
|   # not add to the image size once we gzipped the image. |  | ||||||
|   dd if=/dev/zero of=${MOUNTPOINT}/SWAP.swap bs=1048576 count=512 |  | ||||||
|   mkswap ${MOUNTPOINT}/SWAP.swap |  | ||||||
| 
 |  | ||||||
|   # make sure we dont have the buildd name set as hostname (LP: #605972) |  | ||||||
|   echo "localhost" >${MOUNTPOINT}/etc/hostname |  | ||||||
| 
 |  | ||||||
|   # clean up |  | ||||||
|   umount ${MOUNTPOINT} |  | ||||||
|   rm -rf ${MOUNTPOINT} |  | ||||||
|   losetup -d $DEV || true |  | ||||||
|   chmod 644 livecd.${FSS}.ext2 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| checkpoint() |  | ||||||
| { |  | ||||||
|   echo "===== $1 =====" |  | ||||||
|   date |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| if [ $(id -u) != 0 ];then |  | ||||||
|   echo "must be run as root" |  | ||||||
|   exit 2 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| checkpoint "Starting build" |  | ||||||
| 
 |  | ||||||
| umask 022 |  | ||||||
| export TTY=unknown |  | ||||||
| export TERM=vt100 |  | ||||||
| export DEBIAN_FRONTEND=noninteractive |  | ||||||
| export LANG=C |  | ||||||
| export CASPER_GENERATE_UUID=1 |  | ||||||
| SRCMIRROR=http://archive.ubuntu.com/ubuntu |  | ||||||
| PPAMIRROR=ppa.launchpad.net |  | ||||||
| ARCH=$(dpkg --print-architecture) |  | ||||||
| OPTMIRROR= |  | ||||||
| INITRD_COMPRESSOR=lzma |  | ||||||
| TMPFS=no |  | ||||||
| 
 |  | ||||||
| select_mirror () { |  | ||||||
|     case $ARCH in |  | ||||||
| 	i386|amd64) |  | ||||||
| 	    case $FS in |  | ||||||
| 		ubuntu-lpia|ubuntu-mid) |  | ||||||
| 		    USERMIRROR=http://ports.ubuntu.com/ubuntu-ports |  | ||||||
| 		    SECMIRROR=${USERMIRROR} |  | ||||||
| 		    SECSRCMIRROR=${SRCMIRROR} |  | ||||||
| 		    TARGETARCH=lpia |  | ||||||
| 		    ;; |  | ||||||
| 		*) |  | ||||||
| 		    USERMIRROR=http://archive.ubuntu.com/ubuntu |  | ||||||
| 		    SECMIRROR=http://security.ubuntu.com/ubuntu |  | ||||||
| 		    SECSRCMIRROR=${SECMIRROR} |  | ||||||
| 		    TARGETARCH=${ARCH} |  | ||||||
| 		    ;; |  | ||||||
| 	    esac |  | ||||||
| 	    ;; |  | ||||||
| 	*) |  | ||||||
| 	    USERMIRROR=http://ports.ubuntu.com/ubuntu-ports |  | ||||||
| 	    SECMIRROR=${USERMIRROR} |  | ||||||
| 	    SECSRCMIRROR=${SRCMIRROR} |  | ||||||
| 	    TARGETARCH=${ARCH} |  | ||||||
| 	    ;; |  | ||||||
|     esac |  | ||||||
|     case $(hostname --fqdn) in |  | ||||||
| 	bld-*.mmjgroup.com)	MIRROR=${USERMIRROR};; |  | ||||||
| 	*.mmjgroup.com)		MIRROR=http://archive.mmjgroup.com/${USERMIRROR##*/};; |  | ||||||
| 	*.0c3.net) |  | ||||||
| 		case $ARCH in |  | ||||||
| 			i386|amd64)	MIRROR=http://mirrors.0c3.net/ubuntu/ ;; |  | ||||||
| 			*)		MIRROR=http://mirrors.0c3.net/ubuntu-ports/ ;; |  | ||||||
| 		esac |  | ||||||
| 		;; |  | ||||||
| 	*.ubuntu.com)		MIRROR=http://ftpmaster.internal/ubuntu;; |  | ||||||
| 	*.warthogs.hbd.com)	MIRROR=http://ftpmaster.internal/ubuntu;; |  | ||||||
| 	*.buildd)		MIRROR=http://ftpmaster.internal/ubuntu;; |  | ||||||
| 	*)			MIRROR=${USERMIRROR};; |  | ||||||
|     esac |  | ||||||
| 
 |  | ||||||
|     if [ "$OPTMIRROR" ]; then |  | ||||||
| 	MIRROR="$OPTMIRROR" |  | ||||||
|     fi |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| STE=$(lsb_release -cs) |  | ||||||
| EXCLUDE="" |  | ||||||
| LIST="" |  | ||||||
| SUBARCH="" |  | ||||||
| PROPOSED="" |  | ||||||
| IMAGEFORMAT="squashfs" |  | ||||||
| # must be in the "team / PPA name" form; e.g. "moblin/ppa"; the default PPA |  | ||||||
| # name is "ppa", don't omit it |  | ||||||
| PPA="" |  | ||||||
| APT_SOURCE="" |  | ||||||
| FORCE_YES="" |  | ||||||
| 
 |  | ||||||
| while getopts :d:e:i:I:m:S:s:a:A:f:p name; do case $name in |  | ||||||
|     d)  STE=$OPTARG;; |  | ||||||
|     e)  EXCLUDE="$EXCLUDE $OPTARG";; |  | ||||||
|     i)  LIST="$LIST $OPTARG";; |  | ||||||
|     I)	UINUM="$OPTARG";; |  | ||||||
|     m)	OPTMIRROR="$OPTARG";; |  | ||||||
|     S)	USZ="$OPTARG";; |  | ||||||
|     s)	SUBARCH="$OPTARG";; |  | ||||||
|     a)	ARCH="$OPTARG";; |  | ||||||
|     A)	APT_SOURCE="$OPTARG";; |  | ||||||
|     f)	IMAGEFORMAT="$OPTARG";; |  | ||||||
|     p)  PROPOSED="yes";; |  | ||||||
|     \?) echo bad usage >&2; exit 2;; |  | ||||||
|     \:) echo missing argument >&2; exit 2;; |  | ||||||
| esac; done; |  | ||||||
| shift $((OPTIND-1)) |  | ||||||
| 
 |  | ||||||
| if (( $# == 0 )) || [ "X$1" = "Xall" ]; then |  | ||||||
|     set -- ubuntu kubuntu kubuntu-active edubuntu xubuntu mythbuntu gobuntu base ubuntu-headless cloud-live |  | ||||||
|     if [ "$ARCH" = "i386" ]; then |  | ||||||
|         set -- ubuntu ubuntu-dvd kubuntu kubuntu-dvd kubuntu-active edubuntu edubuntu-dvd mythbuntu xubuntu gobuntu base ubuntu-headless |  | ||||||
|     fi |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if [ "$IMAGEFORMAT" = "ext2" ] || [ "$IMAGEFORMAT" = "ext3" ]; then |  | ||||||
|     LIVE_BOOT_SCRIPTS="jasper" |  | ||||||
| else |  | ||||||
|     LIVE_BOOT_SCRIPTS="casper lupin-casper" |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| for arg in "$@"; do |  | ||||||
|     case "$arg" in |  | ||||||
|        ubuntu|ubuntu-dvd|ubuntu-lpia|edubuntu|edubuntu-dvd|kubuntu|kubuntu-dvd|kubuntu-active|xubuntu|mythbuntu|gobuntu|ubuntu-mid|ubuntu-netbook|ubuntu-moblin-remix|base|ubuntu-headless|tocd|cloud-live) |  | ||||||
| 	    ;; |  | ||||||
| 	*) |  | ||||||
| 	    echo bad name >&2; |  | ||||||
| 	    exit 2 |  | ||||||
| 	    ;; |  | ||||||
|     esac |  | ||||||
| done |  | ||||||
| 
 |  | ||||||
| ROOT=$(pwd)/chroot-livecd/	# trailing / is CRITICAL |  | ||||||
| for FS in "$@"; do |  | ||||||
|     FSS="$FS${SUBARCH:+-$SUBARCH}" |  | ||||||
|     IMG=livecd.${FSS}.fsimg |  | ||||||
|     DEV="" |  | ||||||
|     COMP="main restricted" |  | ||||||
| 
 |  | ||||||
|     select_mirror |  | ||||||
| 
 |  | ||||||
|     # Just in case there's some leftover junk here: |  | ||||||
|     cleanup 2>/dev/null || true |  | ||||||
| 
 |  | ||||||
|     umount ${ROOT} || true |  | ||||||
|     rm -rf ${ROOT} |  | ||||||
|     mkdir ${ROOT} |  | ||||||
|     # maybe use a tmpfs |  | ||||||
|     if  test yes = "$TMPFS"; then |  | ||||||
|         mount -t tmpfs -o size=8192M tmpfs ${ROOT} && echo using tmpfs |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     mkdir -p ${ROOT}etc/dpkg/dpkg.cfg.d |  | ||||||
|     cat << @@EOF > ${ROOT}etc/dpkg/dpkg.cfg.d/livecd-rootfs |  | ||||||
| force-unsafe-io |  | ||||||
| @@EOF |  | ||||||
| 
 |  | ||||||
|     mkdir -p ${ROOT}var/cache/debconf |  | ||||||
|     cat << @@EOF > ${ROOT}var/cache/debconf/config.dat |  | ||||||
| Name: debconf/frontend |  | ||||||
| Template: debconf/frontend |  | ||||||
| Value: Noninteractive |  | ||||||
| Owners: debconf |  | ||||||
| Flags: seen |  | ||||||
| 
 |  | ||||||
| @@EOF |  | ||||||
| 
 |  | ||||||
|     case "$FS" in |  | ||||||
| 	ubuntu|ubuntu-lpia|ubuntu-dvd) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ ubuntu-desktop^" |  | ||||||
| 	    LIVELIST="ubuntu-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    ;; |  | ||||||
| 	kubuntu|kubuntu-dvd) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ kubuntu-desktop^" |  | ||||||
| 	    LIVELIST="kubuntu-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    ;; |  | ||||||
| 	kubuntu-active) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ kubuntu-active^" |  | ||||||
| 	    LIVELIST="kubuntu-active-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    COMP="main restricted universe" |  | ||||||
| 	    ;; |  | ||||||
| 	edubuntu|edubuntu-dvd) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ edubuntu-desktop-gnome^" |  | ||||||
| 	    LIVELIST="edubuntu-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    COMP="main restricted universe" |  | ||||||
| 	    ;; |  | ||||||
| 	xubuntu) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ xterm xubuntu-desktop^" |  | ||||||
| 	    LIVELIST="xubuntu-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    COMP="main restricted universe multiverse" |  | ||||||
| 	    ;; |  | ||||||
| 	gobuntu) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ gobuntu-desktop^" |  | ||||||
| 	    LIVELIST="gobuntu-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    COMP="main" |  | ||||||
| 	    ;; |  | ||||||
| 	ubuntu-mid) |  | ||||||
| 	    LIST="$LIST minimal^ mobile-mid^" |  | ||||||
| 	    LIVELIST="mobile-live^ casper ubiquity" |  | ||||||
| 	    COMP="main restricted universe multiverse" |  | ||||||
| 	    ;; |  | ||||||
| 	ubuntu-netbook) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ ubuntu-netbook^" |  | ||||||
| 	    LIVELIST="netbook-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    ;; |  | ||||||
| 	mythbuntu) |  | ||||||
| 	    LIST="$LIST minimal^ standard^ mythbuntu-desktop^" |  | ||||||
| 	    LIVELIST="mythbuntu-live^ laptop-detect $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    COMP="main restricted universe multiverse" |  | ||||||
| 	    ;; |  | ||||||
| 	ubuntu-moblin-remix) |  | ||||||
| 	    LIST="$LIST minimal^ ubuntu-moblin-remix" |  | ||||||
| 	    LIVELIST="ubuntu-moblin-live" |  | ||||||
| 	    COMP="main restricted universe" |  | ||||||
| 	    PPA="moblin/ppa" |  | ||||||
| 	    ;; |  | ||||||
| 	base) |  | ||||||
| 	    LIST="$LIST minimal^ standard^" |  | ||||||
| 	    LIVELIST="$LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    ;; |  | ||||||
| 	ubuntu-headless) |  | ||||||
| 	    LIST="$LIST minimal^ standard^" |  | ||||||
| 	    LIVELIST="$LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    ;; |  | ||||||
| 	cloud-live) |  | ||||||
| 	    LIST="$LIST minimal^ standard^" |  | ||||||
| 	    LIVELIST="minimal^ standard^ cloud-live-config $LIVE_BOOT_SCRIPTS" |  | ||||||
| 	    COMP="main restricted universe" |  | ||||||
| 	    PPA="cloud-live/config" |  | ||||||
| 	    ;; |  | ||||||
| 	tocd) |  | ||||||
| 	    LIST="$LIST minimal^ standard^" |  | ||||||
| 	    tocdtmp=`mktemp -d` || exit 1 |  | ||||||
| 	    tocdgerminate='http://people.ubuntu.com/~cjwatson/germinate-output/tocd3.1-dapper/' |  | ||||||
| 	    if wget -O "$tocdtmp"/desktop "$tocdgerminate"/desktop; then |  | ||||||
| 	        tocddesktop=`awk '{print $1}' "$tocdtmp"/desktop | egrep -v '^-|^Package|^\|' | tr '\n' ' '` |  | ||||||
| 	        echo "TheOpenCD desktop package list is: $tocddesktop" |  | ||||||
| 	    else |  | ||||||
| 	        echo "Unable to fetch tocd-desktop germinate output." |  | ||||||
| 	        [ -d "$tocdtmp" ] && rm -rf "$tocdtmp" |  | ||||||
| 		exit 1 |  | ||||||
| 	    fi |  | ||||||
| 	    if wget -O "$tocdtmp"/live "$tocdgerminate"/live; then |  | ||||||
| 	        tocdlive=`awk '{print $1}' "$tocdtmp"/live | egrep -v '^-|^Package|^\|' | tr '\n' ' '` |  | ||||||
| 	        echo "TheOpenCD live package list is: $tocdlive" |  | ||||||
| 	    else |  | ||||||
| 	        echo "Unable to fetch tocd-live germinate output." |  | ||||||
| 	        [ -d "$tocdtmp" ] && rm -rf "$tocdtmp" |  | ||||||
| 		exit 1 |  | ||||||
| 	    fi |  | ||||||
| 	    [ -d "$tocdtmp" ] && rm -rf "$tocdtmp" |  | ||||||
| 	    LIST="$LIST $tocddesktop" |  | ||||||
| 	    LIVELIST="$tocdlive casper" |  | ||||||
|     esac |  | ||||||
|     case "$FS" in |  | ||||||
| 	*-dvd) |  | ||||||
| 	    LIVELIST="$LIVELIST ${FS}-live^" |  | ||||||
| 	    UNIVERSE=1 |  | ||||||
| 	    MULTIVERSE=1 |  | ||||||
| 	    ;; |  | ||||||
| 	*) |  | ||||||
| 	    UNIVERSE= |  | ||||||
| 	    MULTIVERSE= |  | ||||||
| 	    ;; |  | ||||||
|     esac |  | ||||||
| 
 |  | ||||||
|     dpkg -l livecd-rootfs || true	# get our version # in the log. |  | ||||||
|     checkpoint "Bootstrapping base system" |  | ||||||
|     debootstrap --components=$(echo $COMP | sed 's/ /,/g') --arch $TARGETARCH $STE $ROOT $MIRROR |  | ||||||
| 
 |  | ||||||
|     # Recent dpkg has started complaining pretty loudly if dev/pts isn't  |  | ||||||
|     # mounted, so let's get it mounted immediately after debootstrap: |  | ||||||
|     mount -t devpts devpts-${STE}-${FSS}-livefs ${ROOT}dev/pts |  | ||||||
| 
 |  | ||||||
|     # Just make a few things go away, which lets us skip a few other things. |  | ||||||
|     DIVERTS="usr/sbin/mkinitrd usr/sbin/invoke-rc.d" |  | ||||||
|     for file in $DIVERTS; do |  | ||||||
| 	mkdir -p ${ROOT}${file%/*} |  | ||||||
| 	chroot $ROOT dpkg-divert --add --local --divert /${file}.livecd --rename /${file} |  | ||||||
| 	cp ${ROOT}/bin/true ${ROOT}$file |  | ||||||
|     done |  | ||||||
| 
 |  | ||||||
|     # /bin/true won't cut it for mkinitrd, need to have -o support. |  | ||||||
|     cat << @@EOF > ${ROOT}/usr/sbin/mkinitrd |  | ||||||
| #!/usr/bin/python |  | ||||||
| import sys |  | ||||||
| for i in range(len(sys.argv)): |  | ||||||
|     if sys.argv[i]=='-o': |  | ||||||
| 	open(sys.argv[i+1],"w") |  | ||||||
| @@EOF |  | ||||||
|     chmod 755 ${ROOT}usr/sbin/mkinitrd |  | ||||||
| 
 |  | ||||||
|     trap "cleanup" 0 1 2 3 15 |  | ||||||
| 
 |  | ||||||
|     case $TARGETARCH in |  | ||||||
|         alpha|amd64|i386|ia64|lpia|m68k|mips|mipsel) |  | ||||||
|             link_in_boot=no |  | ||||||
|             ;; |  | ||||||
|         *) |  | ||||||
|             link_in_boot=yes |  | ||||||
|             ;; |  | ||||||
|     esac |  | ||||||
| 
 |  | ||||||
|     # Make a good /etc/kernel-img.conf for the kernel packages |  | ||||||
|     cat << @@EOF >> ${ROOT}etc/kernel-img.conf |  | ||||||
| do_symlinks = yes |  | ||||||
| relative_links = yes |  | ||||||
| do_bootloader = no |  | ||||||
| do_bootfloppy = no |  | ||||||
| do_initrd = yes |  | ||||||
| link_in_boot = $link_in_boot |  | ||||||
| @@EOF |  | ||||||
| 
 |  | ||||||
|     mkdir -p ${ROOT}proc |  | ||||||
|     mount -tproc none ${ROOT}proc |  | ||||||
| 
 |  | ||||||
|     # this indicates whether or not to keep /boot/vmlinuz; the default is to |  | ||||||
|     # strip it from the livefs as ubiquity >= 1.9.4 copies the kernel from the |  | ||||||
|     # CD root (/casper/vmlinuz) to the target if it doesn't find one on the |  | ||||||
|     # livefs, allowing us to save space; however some subarches use the uImage |  | ||||||
|     # format in casper/ so we would end up with no vmlinuz file in /boot at the |  | ||||||
|     # end. Not stripping it in the first place from /boot saves us from that. |  | ||||||
|     STRIP_VMLINUZ=yes |  | ||||||
| 
 |  | ||||||
|     case $TARGETARCH+$SUBARCH in |  | ||||||
| 	powerpc+ps3) |  | ||||||
| 	    mkdir -p ${ROOT}spu;; |  | ||||||
|     esac |  | ||||||
| 
 |  | ||||||
|     case $TARGETARCH in |  | ||||||
| 	amd64)		LIST="$LIST linux-generic";; |  | ||||||
| 	i386)		LIST="$LIST linux-generic";; |  | ||||||
| 
 |  | ||||||
| 	# and the bastard stepchildren |  | ||||||
| 	lpia)		LIST="$LIST linux-lpia";; |  | ||||||
| 	ia64)		LIST="$LIST linux-ia64";; |  | ||||||
| 	hppa)		LIST="$LIST linux-hppa32 linux-hppa64";; |  | ||||||
| 	powerpc)	LIST="$LIST linux-powerpc linux-powerpc64-smp";; |  | ||||||
| 	sparc*)		LIST="$LIST linux-sparc64";; |  | ||||||
| 	armel) |  | ||||||
| 			#inhibit running of flash-kernel for armel |  | ||||||
|     			export FLASH_KERNEL_SKIP=1 |  | ||||||
| 			case "$SUBARCH" in |  | ||||||
| 				imx51) |  | ||||||
| 					LIST="$LIST linux-imx51" |  | ||||||
| 					;; |  | ||||||
| 				dove) |  | ||||||
| 					LIST="$LIST linux-dove" |  | ||||||
| 					STRIP_VMLINUZ=no |  | ||||||
| 					;; |  | ||||||
| 				omap) |  | ||||||
| 					LIST="$LIST linux-omap x-loader-omap3-beagle u-boot-linaro-omap3-beagle" |  | ||||||
| 					STRIP_VMLINUZ=no |  | ||||||
| 					;; |  | ||||||
| 				omap4) |  | ||||||
| 					LIST="$LIST linux-omap4 x-loader-omap4-panda u-boot-linaro-omap4-panda" |  | ||||||
| 					STRIP_VMLINUZ=no |  | ||||||
| 					;; |  | ||||||
| 			esac;; |  | ||||||
| 	*)		echo "Unknown architecture: no kernel."; exit 1;; |  | ||||||
|     esac |  | ||||||
| 
 |  | ||||||
|     for x in $EXCLUDE; do |  | ||||||
| 	LIST="$(without_package "$x" "$LIST")" |  | ||||||
|     done |  | ||||||
| 
 |  | ||||||
|     if [ "$STE" = "hardy" ]; then |  | ||||||
| 	# <hack, hack, hack> use the version of ssl-cert from the release |  | ||||||
| 	# pocket, because the version in -updates pulls in the large |  | ||||||
| 	# openssl-blacklist package which we should never need on the |  | ||||||
| 	# live CD |  | ||||||
| 	cat << @@EOF > ${ROOT}etc/apt/preferences |  | ||||||
| Package: ssl-cert |  | ||||||
| Pin: version 1.0.14-0ubuntu2 |  | ||||||
| Pin-Priority: 991 |  | ||||||
| @@EOF |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # Create a good sources.list, and finish the install |  | ||||||
|     checkpoint "Configuring APT" |  | ||||||
|     echo deb $MIRROR $STE ${COMP} > ${ROOT}etc/apt/sources.list |  | ||||||
|     echo deb $MIRROR ${STE}-security ${COMP} >> ${ROOT}etc/apt/sources.list |  | ||||||
|     echo deb $MIRROR ${STE}-updates ${COMP} >> ${ROOT}etc/apt/sources.list |  | ||||||
|     if [ "$PROPOSED" = "yes" ]; then |  | ||||||
|         echo deb $MIRROR ${STE}-proposed ${COMP} >> ${ROOT}etc/apt/sources.list |  | ||||||
|     fi |  | ||||||
|     if [ -n "$PPA" ]; then |  | ||||||
|         echo deb http://$PPAMIRROR/$PPA/ubuntu ${STE} main >> ${ROOT}etc/apt/sources.list |  | ||||||
| 
 |  | ||||||
|         # handle PPAs named "ppa" specially; their Origin field in the Release |  | ||||||
|         # file does not end with "-ppa" for backwards compatibility |  | ||||||
|         origin="${PPA%/ppa}" |  | ||||||
|         origin="${origin/\//-}" |  | ||||||
|         touch ${ROOT}etc/apt/preferences |  | ||||||
|         cat << @@EOF >> ${ROOT}etc/apt/preferences |  | ||||||
| Package: * |  | ||||||
| Pin: release o=LP-PPA-$origin |  | ||||||
| Pin-Priority: 550 |  | ||||||
| @@EOF |  | ||||||
|     fi |  | ||||||
|     if [ -n "$APT_SOURCE" ]; then |  | ||||||
| 	echo deb $APT_SOURCE $STE $COMP >> ${ROOT}etc/apt/sources.list |  | ||||||
| 	# allow unsigned sources, unfortunately |  | ||||||
| 	mkdir -p ${ROOT}etc/apt/apt.conf.d |  | ||||||
| 	echo 'APT::Get::AllowUnauthenticated "yes";' > ${ROOT}etc/apt/apt.conf.d/extra-source-allows-unauthenticated-sources |  | ||||||
| 	# and add the preferences rules :( |  | ||||||
| 	APT_PIN=$(echo $APT_SOURCE | sed -e's,http://,,; s,/.*,,') |  | ||||||
| 	cat >> ${ROOT}etc/apt/preferences << @@EOF |  | ||||||
| Package: * |  | ||||||
| Pin: release a=$STE |  | ||||||
| Pin-Priority: 500 |  | ||||||
| 
 |  | ||||||
| Package: * |  | ||||||
| Pin: origin $APT_PIN |  | ||||||
| Pin-Priority: 900 |  | ||||||
| @@EOF |  | ||||||
| 	FORCE_YES=--force-yes |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     if [ "$FS" = "ubuntu-moblin-remix" ]; then |  | ||||||
| 	chroot $ROOT apt-get update |  | ||||||
| 	chroot $ROOT apt-get -y --force-yes install ubuntu-moblin-ppa-keyring |  | ||||||
| 	# promote Release.gpg from APT's lists/partial/ to lists/ |  | ||||||
| 	chroot $ROOT apt-get update |  | ||||||
| 	# workaround LP #442082 |  | ||||||
| 	rm -f ${ROOT}var/cache/apt/{,src}pkgcache.bin |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     if [ "$FS" = "cloud-live" ]; then |  | ||||||
| 	chroot $ROOT apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F3531FCE |  | ||||||
| 	chroot $ROOT apt-get update |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # In addition to the ones we got from apt, trust whatever the local system |  | ||||||
|     # believes in, but put things back afterwards. |  | ||||||
|     cp ${ROOT}etc/apt/trusted.gpg ${ROOT}etc/apt/trusted.gpg.$$ |  | ||||||
|     cat /etc/apt/trusted.gpg >> ${ROOT}etc/apt/trusted.gpg |  | ||||||
| 
 |  | ||||||
|     # update and immediately restore the trusted keyring |  | ||||||
|     chroot $ROOT apt-get update |  | ||||||
|     # we restore the keyring here because on dist-upgrade the |  | ||||||
|     # ubuntu-extras-keyring package installs additional keys |  | ||||||
|     mv ${ROOT}etc/apt/trusted.gpg.$$ ${ROOT}etc/apt/trusted.gpg |  | ||||||
| 
 |  | ||||||
|     checkpoint "Upgrading" |  | ||||||
|     chroot $ROOT apt-get -y $FORCE_YES --purge dist-upgrade </dev/null |  | ||||||
|     checkpoint "Installing main packages" |  | ||||||
|     chroot $ROOT apt-get -y --purge install $LIST </dev/null |  | ||||||
| 
 |  | ||||||
|     # launchpad likes to put dependencies of seeded packages in tasks along with the |  | ||||||
|     # actual seeded packages.  In general, this isn't an issue.  With updated kernels |  | ||||||
|     # and point-releases, though, we end up with extra header packages: |  | ||||||
|     checkpoint "Cleaning up kernel headers" |  | ||||||
|     chroot ${ROOT} dpkg -l linux-headers-2\* | grep ^i | awk '{print $2}' \ |  | ||||||
|         > livecd.${FSS}.manifest-headers |  | ||||||
|     chroot ${ROOT} dpkg -l linux-headers-\* | grep ^i | awk '{print $2}' \ |  | ||||||
|         > livecd.${FSS}.manifest-headers-full |  | ||||||
|     HEADERPACKAGES=`cat livecd.${FSS}.manifest-headers-full` |  | ||||||
|     HEADERMETA="" |  | ||||||
|     for i in `comm -3 livecd.${FSS}.manifest-headers livecd.${FSS}.manifest-headers-full`; do |  | ||||||
|         HEADERMETA="$HEADERMETA $i" |  | ||||||
|     done |  | ||||||
|     case $TARGETARCH in |  | ||||||
|         armel) |  | ||||||
|             HEADERMETA=linux-headers-${SUBARCH} |  | ||||||
|             ;; |  | ||||||
|     esac |  | ||||||
|     rm -f livecd.${FSS}.manifest-headers livecd.${FSS}.manifest-headers-full |  | ||||||
|     chroot ${ROOT} apt-get -y --purge remove $HEADERPACKAGES </dev/null || true |  | ||||||
|     chroot ${ROOT} apt-get -y --purge install $HEADERMETA </dev/null || true |  | ||||||
|     # End horrible linux-header launchpad workaround.  Hopefully this is temporary. |  | ||||||
| 
 |  | ||||||
|     chroot ${ROOT} dpkg-query -W --showformat='${Package} ${Version}\n' \ |  | ||||||
| 	> livecd.${FSS}.manifest-desktop |  | ||||||
|     checkpoint "Installing live packages" |  | ||||||
|     chroot $ROOT apt-get -y --purge install $LIVELIST </dev/null |  | ||||||
|     case $FS in |  | ||||||
| 	edubuntu) |  | ||||||
| 	    chroot $ROOT apt-cache dumpavail | \ |  | ||||||
| 		grep-dctrl -nsPackage -FTask edubuntu-ship-addon -a \ |  | ||||||
| 				      -FTask edubuntu-live | \ |  | ||||||
| 		sort -u | \ |  | ||||||
| 		xargs chroot $ROOT \ |  | ||||||
| 		    dpkg-query -W --showformat='${Package} ${Version}\n' \ |  | ||||||
| 		>> livecd.${FSS}.manifest-desktop |  | ||||||
| 	    ;; |  | ||||||
|     esac |  | ||||||
|     chroot ${ROOT} dpkg-query -W --showformat='${Package} ${Version}\n' \ |  | ||||||
| 	> livecd.${FSS}.manifest |  | ||||||
| 
 |  | ||||||
|     checkpoint "Cleaning up" |  | ||||||
| 
 |  | ||||||
|     kill_users |  | ||||||
| 
 |  | ||||||
|     chroot $ROOT /etc/cron.daily/mlocate || true |  | ||||||
|     chroot $ROOT /etc/cron.daily/man-db	|| true |  | ||||||
| 
 |  | ||||||
|     # remove our diversions |  | ||||||
|     for file in $DIVERTS; do |  | ||||||
| 	ls -ld ${ROOT}${file} ${ROOT}${file}.livecd || true |  | ||||||
| 	rm -f ${ROOT}${file} |  | ||||||
| 	chroot $ROOT dpkg-divert --remove --rename /${file} |  | ||||||
|     done |  | ||||||
| 
 |  | ||||||
|     # remove the apt preferences hack if it was added |  | ||||||
|     rm -f ${ROOT}etc/apt/preferences |  | ||||||
| 
 |  | ||||||
|     # And make this look more pristine |  | ||||||
|     cat << @@EOF > ${ROOT}etc/apt/sources.list |  | ||||||
| deb ${USERMIRROR} $STE ${COMP} |  | ||||||
| deb-src ${SRCMIRROR} $STE ${COMP} |  | ||||||
| 
 |  | ||||||
| deb ${SECMIRROR} ${STE}-security ${COMP} |  | ||||||
| deb-src ${SECSRCMIRROR} ${STE}-security ${COMP} |  | ||||||
| 
 |  | ||||||
| ## Major bug fix updates produced after the final release of the |  | ||||||
| ## distribution. |  | ||||||
| deb ${USERMIRROR} ${STE}-updates ${COMP} |  | ||||||
| deb-src ${SRCMIRROR} ${STE}-updates ${COMP} |  | ||||||
| 
 |  | ||||||
| @@EOF |  | ||||||
|     if [ "$UNIVERSE" ]; then |  | ||||||
| 	COMMENT= |  | ||||||
|     else |  | ||||||
| 	cat << @@EOF >> ${ROOT}etc/apt/sources.list |  | ||||||
| ## Uncomment the following two lines to add software from the 'universe' |  | ||||||
| ## repository. |  | ||||||
| @@EOF |  | ||||||
| 	COMMENT='# ' |  | ||||||
|     fi |  | ||||||
|     cat << @@EOF >> ${ROOT}etc/apt/sources.list |  | ||||||
| ## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu |  | ||||||
| ## team. Also, please note that software in universe WILL NOT receive any |  | ||||||
| ## review or updates from the Ubuntu security team. |  | ||||||
| ${COMMENT}deb ${USERMIRROR} $STE universe |  | ||||||
| ${COMMENT}deb-src ${SRCMIRROR} $STE universe |  | ||||||
| ${COMMENT}deb ${USERMIRROR} ${STE}-updates universe |  | ||||||
| ${COMMENT}deb-src ${SRCMIRROR} ${STE}-updates universe |  | ||||||
| ${COMMENT}deb ${SECMIRROR} ${STE}-security universe |  | ||||||
| ${COMMENT}deb-src ${SECSRCMIRROR} ${STE}-security universe |  | ||||||
| 
 |  | ||||||
| @@EOF |  | ||||||
|     if [ "$MULTIVERSE" ]; then |  | ||||||
| 	COMMENT= |  | ||||||
|     else |  | ||||||
| 	COMMENT='# ' |  | ||||||
|     fi |  | ||||||
|     cat << @@EOF >> ${ROOT}etc/apt/sources.list |  | ||||||
| ## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu |  | ||||||
| ## team, and may not be under a free licence. Please satisfy yourself as to |  | ||||||
| ## your rights to use the software. Also, please note that software in |  | ||||||
| ## multiverse WILL NOT receive any review or updates from the Ubuntu |  | ||||||
| ## security team. |  | ||||||
| ${COMMENT}deb ${USERMIRROR} $STE multiverse |  | ||||||
| ${COMMENT}deb-src ${SRCMIRROR} $STE multiverse |  | ||||||
| ${COMMENT}deb ${USERMIRROR} ${STE}-updates multiverse |  | ||||||
| ${COMMENT}deb-src ${SRCMIRROR} ${STE}-updates multiverse |  | ||||||
| ${COMMENT}deb ${SECMIRROR} ${STE}-security multiverse |  | ||||||
| ${COMMENT}deb-src ${SECSRCMIRROR} ${STE}-security multiverse |  | ||||||
| @@EOF |  | ||||||
|     if [ -n "$PPA" ]; then |  | ||||||
|     cat << @@EOF >> ${ROOT}etc/apt/sources.list |  | ||||||
| 
 |  | ||||||
| ## The following unsupported and untrusted Personal Archives (PPAs) were used |  | ||||||
| ## to create the base image of this system |  | ||||||
| deb http://$PPAMIRROR/$PPA/ubuntu ${STE} main |  | ||||||
| deb-src http://$PPAMIRROR/$PPA/ubuntu ${STE} main |  | ||||||
| @@EOF |  | ||||||
| 
 |  | ||||||
|         # handle PPAs named "ppa" specially; their Origin field in the Release |  | ||||||
|         # file does not end with "-ppa" for backwards compatibility |  | ||||||
|         origin="${PPA%/ppa}" |  | ||||||
|         origin="${origin/\//-}" |  | ||||||
|         touch ${ROOT}etc/apt/preferences |  | ||||||
|         cat << @@EOF >> ${ROOT}etc/apt/preferences |  | ||||||
| Explanation: This prefers the Personal Archive $PPA over the other sources |  | ||||||
| Package: * |  | ||||||
| Pin: release o=LP-PPA-$origin |  | ||||||
| Pin-Priority: 550 |  | ||||||
| @@EOF |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # get rid of the .debs - we don't need them. |  | ||||||
|     chroot ${ROOT} apt-get clean |  | ||||||
|     rm -f ${ROOT}var/lib/apt/lists/*_* |  | ||||||
|     rm -f ${ROOT}var/spool/postfix/maildrop/* |  | ||||||
|     # Removing update-notifier notes is now considered harmful: |  | ||||||
|     #rm -f ${ROOT}var/lib/update-notifier/user.d/* |  | ||||||
|     # The D-Bus machine identifier needs to be unique, and is generated at |  | ||||||
|     # boot time if it's missing. |  | ||||||
|     rm -f ${ROOT}var/lib/dbus/machine-id |  | ||||||
|     chroot $ROOT apt-get update || true	# give them fresh lists, but don't fail |  | ||||||
|     rm -f ${ROOT}etc/resolv.conf ${ROOT}etc/mailname |  | ||||||
|     if [ -f ${ROOT}/etc/postfix/main.cf ]; then |  | ||||||
| 	sed -i '/^myhostname/d; /^mydestination/d; /^myorigin/d' ${ROOT}etc/postfix/main.cf |  | ||||||
| 	echo set postfix/destinations | chroot ${ROOT} /usr/bin/debconf-communicate postfix |  | ||||||
| 	echo set postfix/mailname | chroot ${ROOT} /usr/bin/debconf-communicate postfix |  | ||||||
|     fi |  | ||||||
|     KVERS=`chroot ${ROOT} dpkg -l linux-image-2\*|grep ^i|awk '{print $2}'|sed 's/linux-image-//'` |  | ||||||
|     for KVER in ${KVERS}; do |  | ||||||
| 	SUBARCH="${KVER#*-*-}" |  | ||||||
| 	chroot ${ROOT} update-initramfs -k "${KVER}" -u |  | ||||||
| 	# we mv the initramfs, so it's not wasting space on the livefs |  | ||||||
| 	mv ${ROOT}/boot/initrd.img-"${KVER}" livecd.${FSS}.initrd-"${SUBARCH}" |  | ||||||
| 	rm -f ${ROOT}/boot/initrd.img-"${KVER}".bak |  | ||||||
| 	# whether to strip vmlinuz or not to save space thanks to ubiquity |  | ||||||
| 	action="cp" |  | ||||||
| 	if [ "$STRIP_VMLINUZ" = "yes" ]; then |  | ||||||
| 	    action="mv" |  | ||||||
| 	fi |  | ||||||
| 	$action ${ROOT}/boot/vmlinu?-"${KVER}" livecd.${FSS}.kernel-"${SUBARCH}" |  | ||||||
| 	chmod 644 livecd.${FSS}.kernel-"${SUBARCH}" |  | ||||||
| 	if [ "$INITRD_COMPRESSOR" != gz ]; then |  | ||||||
| 	    zcat "livecd.${FSS}.initrd-${SUBARCH}" | "$INITRD_COMPRESSOR" -9c \ |  | ||||||
| 		> "livecd.${FSS}.initrd-${SUBARCH}.new" |  | ||||||
| 	    mv "livecd.${FSS}.initrd-${SUBARCH}.new" \ |  | ||||||
| 		"livecd.${FSS}.initrd-${SUBARCH}" |  | ||||||
| 	fi |  | ||||||
|     done |  | ||||||
|     NUMKVERS="$(set -- $KVERS; echo $#)" |  | ||||||
|     if [ "$NUMKVERS" = 1 ]; then |  | ||||||
| 	# only one kernel |  | ||||||
| 	SUBARCH="${KVERS#*-*-}" |  | ||||||
| 	ln -sf livecd.${FSS}.initrd-"${SUBARCH}" livecd.${FSS}.initrd |  | ||||||
| 	ln -sf livecd.${FSS}.kernel-"${SUBARCH}" livecd.${FSS}.kernel |  | ||||||
|     fi |  | ||||||
|     case $TARGETARCH+$SUBARCH in |  | ||||||
| 	powerpc+ps3) |  | ||||||
| 	    chroot ${ROOT} addgroup --system spu;; |  | ||||||
|     esac |  | ||||||
| 
 |  | ||||||
|     # No point keeping Gnome icon cache around for Kubuntu |  | ||||||
|     if [ "$FS" = "kubuntu" ] || \ |  | ||||||
|        [ "$FS" = "kubuntu-active" ]; then |  | ||||||
|         rm -f ${ROOT}/usr/share/icons/*/icon-theme.cache |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     if [ "$FS" = ubuntu-netbook ] && \ |  | ||||||
|        [ "$TARGETARCH" = armel ] && \ |  | ||||||
|        [ -e "$ROOT/usr/share/xsessions/unity-2d.desktop" ]; then |  | ||||||
|         chroot $ROOT /usr/lib/gdm/gdm-set-default-session unity-2d |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # all done with the chroot; reset the debconf frontend, so Colin doesn't cry |  | ||||||
|     echo RESET debconf/frontend | chroot $ROOT debconf-communicate |  | ||||||
|     echo FSET debconf/frontend seen true | chroot $ROOT debconf-communicate |  | ||||||
| 
 |  | ||||||
|     # And now that we're done messing with debconf, destroy the backup files: |  | ||||||
|     rm -f ${ROOT}/var/cache/debconf/*-old |  | ||||||
| 
 |  | ||||||
|     rm -f ${ROOT}/etc/dpkg/dpkg.cfg.d/livecd-rootfs |  | ||||||
| 
 |  | ||||||
|     # show the size of directories in /usr/share/doc |  | ||||||
|     checkpoint "Checking size of /usr/share/doc" |  | ||||||
|     echo BEGIN docdirs |  | ||||||
|     (cd $ROOT && find usr/share/doc -maxdepth 1 -type d | xargs du -s | sort -nr) |  | ||||||
|     echo END docdirs |  | ||||||
| 
 |  | ||||||
|     # search for duplicate files, write the summary to stdout,  |  | ||||||
|     if which fdupes >/dev/null 2>&1; then |  | ||||||
| 	checkpoint "Checking for duplicate files" |  | ||||||
| 	echo "first line: <total size for dupes> <different dupes> <all dupes>" |  | ||||||
| 	echo "data lines: <size for dupes> <number of dupes> <file size> <filename> [<filename> ...]" |  | ||||||
| 	echo BEGIN fdupes |  | ||||||
| 	(cd $ROOT \ |  | ||||||
| 	   && fdupes --recurse --noempty --sameline --size --quiet usr \ |  | ||||||
| 	   | awk '/bytes each/ {s=$1} /^usr/ { n+=1; n2+=NF-1; sum+=s*(NF-1); print s*(NF-1), NF-1, s, $0 } END {print sum, n, n2}' \ |  | ||||||
| 	   | sort -nr |  | ||||||
| 	) |  | ||||||
| 	echo END fdupes |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # Dirty hack to mark langpack stuff as manually installed |  | ||||||
|     perl -i -nle 'print unless /^Package: language-(pack|support)/ .. /^$/;' \ |  | ||||||
|         ${ROOT}/var/lib/apt/extended_states |  | ||||||
| 
 |  | ||||||
|     # And run the cleanup function dead last, to umount /proc after nothing |  | ||||||
|     # else needs to be run in the chroot (umounting it earlier breaks rm): |  | ||||||
|     cleanup |  | ||||||
| 
 |  | ||||||
|     # Squashfs does not report unpacked disk space usage, which is explained at |  | ||||||
|     # <http://lkml.org/lkml/2006/6/16/163>.  However, we would like to cache this |  | ||||||
|     # number for partman's sufficient free space check and ubiquity's |  | ||||||
|     # installation progress calculation. |  | ||||||
|     checkpoint "Calculating total size" |  | ||||||
|     printf $(du -sx --block-size=1 ${ROOT} | cut -f1) > livecd.${FSS}.size || true |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     # Build our images |  | ||||||
|     checkpoint "Building image" |  | ||||||
|     if [ "$IMAGEFORMAT" = "ext2" ] || [ "$IMAGEFORMAT" = "ext3" ]; then |  | ||||||
|         livefs_ext2 |  | ||||||
|     else |  | ||||||
|         livefs_squash |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # Upgrade ext2->ext3 if that's what is requested |  | ||||||
|     if [ "$IMAGEFORMAT" = "ext3" ]; then |  | ||||||
|         tune2fs -j livecd.${FSS}.ext2 |  | ||||||
|         mv livecd.${FSS}.ext2 livecd.${FSS}.ext3 |  | ||||||
|         # temporary workaround for LP: #583317 with ext3 images |  | ||||||
|         e2fsck -fy livecd.${FSS}.ext3 || true |  | ||||||
|     fi |  | ||||||
| 
 |  | ||||||
|     # LTSP chroot building (only in 32bit and for Edubuntu (DVD)) |  | ||||||
|     case $FS in |  | ||||||
|         edubuntu-dvd) |  | ||||||
|             if [ "$TARGETARCH" = "i386" ]; then |  | ||||||
|                 checkpoint "Building LTSP chroot" |  | ||||||
|                 ltsp-build-client --base $(pwd) --mirror $MIRROR --arch $TARGETARCH --dist $STE --chroot ltsp-live --late-packages ldm-edubuntu-theme,plymouth-theme-edubuntu --purge-chroot --skipimage |  | ||||||
|                 mkdir -p $(pwd)/images |  | ||||||
|                 mksquashfs $(pwd)/ltsp-live $(pwd)/images/ltsp-live.img -e cdrom |  | ||||||
|                 rm -Rf $(pwd)/ltsp-live |  | ||||||
|                 if [ -f $(pwd)/images/ltsp-live.img ]; then |  | ||||||
|                     mv $(pwd)/images/ltsp-live.img livecd.$FS-ltsp.squashfs |  | ||||||
|                     chmod 0644 livecd.$FS-ltsp.squashfs |  | ||||||
|                     rmdir --ignore-fail-on-non-empty $(pwd)/images/ |  | ||||||
|                 else |  | ||||||
|                     echo "LTSP: Unable to build the chroot, see above for details." |  | ||||||
|                 fi |  | ||||||
|             fi |  | ||||||
|         ;; |  | ||||||
|     esac |  | ||||||
| done |  | ||||||
| 
 |  | ||||||
| checkpoint "Done" |  | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user