+
+ # TODO
+ # * provide alternative search_file() if file information is stored in a config.ini file?
+ # * catch "install: .. No space left on device" & CO
+ # * abstract copy logic to make the code shorter?
+
+ squashfs = search_file(grml_flavour + '.squashfs', iso_mount)
+ squashfs_target = target + '/live/'
+ mkdir(squashfs_target)
+
+ # use install(1) for now to make sure we can write the files afterwards as normal user as well
+ print("debug: copy squashfs to %s") % target + '/live/' + grml_flavour + '.squashfs'
+ subprocess.Popen(["install", "--mode=664", squashfs, squashfs_target + grml_flavour + ".squashfs"])
+
+ filesystem_module = search_file('filesystem.module', iso_mount)
+ print("debug: copy filesystem.module to %s") % squashfs_target + grml_flavour + '.module'
+ subprocess.Popen(["install", "--mode=664", filesystem_module, squashfs_target + grml_flavour + '.module'])
+
+ release_target = target + '/boot/release/' + grml_flavour
+ mkdir(release_target)
+
+ kernel = search_file('linux26', iso_mount)
+ print("debug: copy kernel to %s") % release_target + '/linux26'
+ subprocess.Popen(["install", "--mode=664", kernel, release_target + '/linux26'])
+
+ initrd = search_file('initrd.gz', iso_mount)
+ print("debug: copy initrd to %s") % release_target + '/initrd.gz'
+ subprocess.Popen(["install", "--mode=664", initrd, release_target + '/initrd.gz'])
+
+ isolinux_target = target + '/boot/isolinux/'
+ mkdir(isolinux_target)
+
+ logo = search_file('logo.16', iso_mount)
+ print("debug: copy logo.16 to %s") % isolinux_target + 'logo.16'
+ subprocess.Popen(["install", "--mode=664", logo, isolinux_target + 'logo.16'])
+
+ for file in 'f2', 'f3', 'f4', 'f5', 'f6', 'f7', 'f8', 'f9', 'f10':
+ bootsplash = search_file(file, iso_mount)
+ print("debug: copy %s to %s") % (bootsplash, isolinux_target + file)
+ subprocess.Popen(["install", "--mode=664", bootsplash, isolinux_target + file])
+
+ grub_target = target + '/boot/grub/'
+ mkdir(grub_target)
+
+ print("debug: copy grub/splash.xpm.gz to %s") % grub_target + 'splash.xpm.gz'
+ subprocess.Popen(["install", "--mode=664", 'grub/splash.xpm.gz', grub_target + 'splash.xpm.gz'])
+
+ print("debug: copy grub/stage2_eltorito to %s") % grub_target + 'stage2_eltorito'
+ subprocess.Popen(["install", "--mode=664", 'grub/stage2_eltorito', grub_target + 'stage2_eltorito'])
+
+ print("debug: generating grub configuration %s") % grub_target + 'menu.lst'
+ grub_config_file = open(grub_target + 'menu.lst', 'w')
+ grub_config_file.write(generate_grub_config(grml_flavour))
+ grub_config_file.close( )
+
+ syslinux_target = target + '/boot/isolinux/'
+ mkdir(syslinux_target)
+
+ print("debug: generating syslinux configuration %s") % syslinux_target + 'syslinux.cfg'
+ syslinux_config_file = open(syslinux_target + 'syslinux.cfg', 'w')
+ syslinux_config_file.write(generate_syslinux_config(grml_flavour))
+ syslinux_config_file.close( )
+
+ print("debug: generating isolinux/syslinux splash %s") % syslinux_target + 'boot.msg'
+ isolinux_splash = open(syslinux_target + 'boot.msg', 'w')
+ isolinux_splash.write(generate_isolinux_splash(grml_flavour))
+ isolinux_splash.close( )