-- Do nothing unless explicitly requested in tup.config. build_type = tup.getconfig('BUILD_TYPE') if build_type == "" then return end --[================================[ DATA ]================================]-- PROGS = "../programs" -- Static data that doesn't need to be compiled -- Files to be included in kolibri.img. -- The first subitem of every item is name inside kolibri.img, the second is name of local file. img_files = { {"MACROS.INC", PROGS .. "/macros.inc"}, {"CONFIG.INC", PROGS .. "/config.inc"}, {"STRUCT.INC", PROGS .. "/struct.inc"}, {"FB2READ", "common/fb2read"}, {"ALLGAMES", "common/allgames"}, {"HOME.PNG", "common/wallpapers/T_Home.png"}, {"ICONS32.PNG", "common/icons32.png"}, {"ICONS16.PNG", "common/icons16.png"}, {"INDEX.HTM", "common/index_htm"}, {"KUZKINA.MID", "common/kuzkina.mid"}, {"SINE.MP3", "common/sine.mp3"}, {"LANG.INC", build_type .. "/lang.inc"}, {"NOTIFY3.PNG", "common/notify3.png"}, {"UNIMG", PROGS .. "/fs/unimg/unimg"}, {"3D/HOUSE.3DS", "common/3d/house.3ds"}, {"File Managers/ICONS.INI", "common/File Managers/icons.ini"}, {"File Managers/FNAV/ABOUT.TXT", "common/File Managers/fNav/ABOUT.TXT"}, {"File Managers/FNAV/FNAV", "common/File Managers/fNav/FNAV"}, {"File Managers/FNAV/FNAV.EXT", "common/File Managers/fNav/FNAV.EXT"}, {"File Managers/FNAV/FNAV.SET", "common/File Managers/fNav/FNAV.SET"}, {"File Managers/FNAV/FNAV_CUR.PNG", "common/File Managers/fNav/FNAV_CUR.PNG"}, {"File Managers/FNAV/FNAV_FNT.PNG", "common/File Managers/fNav/FNAV_FNT.PNG"}, {"File Managers/FNAV/FNAV_ICN.PNG", "common/File Managers/fNav/FNAV_ICN.PNG"}, {"GAMES/FLPYBIRD", PROGS .. "/games/flappybird/Release/flappybird"}, {"FONTS/TAHOMA.KF", "common/fonts/tahoma.kf"}, -- {"LIB/ICONV.OBJ", "common/lib/iconv.obj"}, {"LIB/KMENU.OBJ", "common/lib/kmenu.obj"}, {"LIB/PIXLIB.OBJ", "common/lib/pixlib.obj"}, {"MEDIA/IMGF/IMGF", "common/media/ImgF/ImgF"}, {"MEDIA/IMGF/CEDG.OBJ", "common/media/ImgF/cEdg.obj"}, {"MEDIA/IMGF/DITHER.OBJ", "common/media/ImgF/dither.obj"}, {"MEDIA/IMGF/INVSOL.OBJ", "common/media/ImgF/invSol.obj"}, {"MEDIA/PIXIESKN.PNG", PROGS .. "/cmm/pixie2/pixieskn.png"}, {"NETWORK/FTPC.INI", PROGS .. "/network/ftpc/ftpc.ini"}, {"NETWORK/FTPD.INI", "common/network/ftpd.ini"}, {"NETWORK/USERS.INI", "common/network/users.ini"}, {"NETWORK/FTPC_SYS.PNG", PROGS .. "/network/ftpc/ftpc_sys.png"}, {"NETWORK/FTPC_NOD.PNG", PROGS .. "/network/ftpc/ftpc_nod.png"}, {"SETTINGS/APP.INI", "common/settings/app.ini"}, {"SETTINGS/APP_PLUS.INI", "common/settings/app_plus.ini"}, {"SETTINGS/ASSOC.INI", "common/settings/assoc.ini"}, {"SETTINGS/AUTORUN.DAT", "common/settings/AUTORUN.DAT"}, {"SETTINGS/CEDIT.INI", PROGS .. "/develop/cedit/CEDIT.INI"}, {"SETTINGS/DOCKY.INI", "common/settings/docky.ini"}, {"SETTINGS/FB2READ.INI", "common/settings/fb2read.ini"}, {"SETTINGS/HOTANGLES.CFG", PROGS .. "/other/ha/SETTINGS/HOTANGLES.CFG"}, {"SETTINGS/ICON.INI", build_type .. "/settings/icon.ini"}, {"SETTINGS/KEYMAP.KEY", PROGS .. "/system/taskbar/trunk/KEYMAP.KEY"}, {"SETTINGS/KOLIBRI.LBL", build_type .. "/settings/kolibri.lbl"}, {"SETTINGS/LANG.INI", build_type .. "/settings/lang.ini"}, {"SETTINGS/MENU.DAT", build_type .. "/settings/menu.dat"}, {"SETTINGS/NETWORK.INI", "common/settings/network.ini"}, {"SETTINGS/SYSTEM.INI", "common/settings/system.ini"}, {"SETTINGS/TASKBAR.INI", "common/settings/taskbar.ini"}, {"SETTINGS/weather.json", PROGS .. "/other/Weather/weather.json"}, } -- For russian build, add russian-only files. if build_type == "rus" then tup.append_table(img_files, { {"EXAMPLE.ASM", PROGS .. "/develop/examples/example/trunk/rus/example.asm"}, {"DEVELOP/BACKY", PROGS .. "/develop/backy/Backy_ru"}, {"GAMES/BASEKURS.KLA", build_type .. "/games/basekurs.kla"}, {"File Managers/KFAR.INI", build_type .. "/File Managers/kfar.ini"}, {"GAMES/DESCENT", build_type .. "/games/descent"}, {"SETTINGS/.shell", PROGS .. "/system/shell/bin/rus/.shell"}, {"SETTINGS/GAMES.INI", "rus/settings/games.ini"}, {"SETTINGS/MYKEY.INI", PROGS .. "/system/MyKey/trunk/mykey.ini"}, {"SETTINGS/SYSPANEL.INI", "rus/settings/syspanel.ini"}, }) elseif build_type == "eng" then tup.append_table(img_files, { {"EXAMPLE.ASM", PROGS .. "/develop/examples/example/trunk/example.asm"}, {"DEVELOP/BACKY", PROGS .. "/develop/backy/Backy"}, {"File Managers/KFAR.INI", "common/File Managers/kfar.ini"}, {"GAMES/DESCENT", "common/games/descent"}, {"SETTINGS/.shell", PROGS .. "/system/shell/bin/eng/.shell"}, {"SETTINGS/GAMES.INI", "common/settings/games.ini"}, {"SETTINGS/MYKEY.INI", PROGS .. "/system/MyKey/trunk/mykey.ini"}, {"SETTINGS/SYSPANEL.INI", "common/settings/syspanel.ini"}, }) elseif build_type == "sp" then tup.append_table(img_files, { {"EXAMPLE.ASM", PROGS .. "/develop/examples/example/trunk/example.asm"}, {"DEVELOP/BACKY", PROGS .. "/develop/backy/Backy"}, {"File Managers/KFAR.INI", "common/File Managers/kfar.ini"}, {"GAMES/DESCENT", "common/games/descent"}, {"SETTINGS/.shell", PROGS .. "/system/shell/bin/eng/.shell"}, {"SETTINGS/GAMES.INI", "common/settings/games.ini"}, {"SETTINGS/MYKEY.INI", PROGS .. "/system/MyKey/trunk/mykey.ini"}, {"SETTINGS/SYSPANEL.INI", "common/settings/syspanel.ini"}, }) elseif build_type == "it" then tup.append_table(img_files, { {"EXAMPLE.ASM", PROGS .. "/develop/examples/example/trunk/example.asm"}, {"DEVELOP/BACKY", PROGS .. "/develop/backy/Backy"}, {"File Managers/KFAR.INI", "common/File Managers/kfar.ini"}, {"GAMES/DESCENT", "common/games/descent"}, {"SETTINGS/.shell", PROGS .. "/system/shell/bin/eng/.shell"}, {"SETTINGS/MYKEY.INI", PROGS .. "/system/MyKey/trunk/mykey_it.ini"}, {"SETTINGS/GAMES.INI", "common/settings/games.ini"}, {"SETTINGS/SYSPANEL.INI", "common/settings/syspanel.ini"}, }) else tup.append_table(img_files, { {"EXAMPLE.ASM", PROGS .. "/develop/examples/example/trunk/example.asm"}, {"DEVELOP/BACKY", PROGS .. "/develop/backy/Backy"}, {"File Managers/KFAR.INI", "common/File Managers/kfar.ini"}, {"GAMES/DESCENT", "common/games/descent"}, {"SETTINGS/.shell", PROGS .. "/system/shell/bin/eng/.shell"}, {"SETTINGS/GAMES.INI", "common/settings/games.ini"}, {"SETTINGS/MYKEY.INI", PROGS .. "/system/MyKey/trunk/mykey.ini"}, {"SETTINGS/SYSPANEL.INI", "common/settings/syspanel.ini"}, }) end --[[ Files to be included in kolibri.iso and distribution kit outside of kolibri.img. The first subitem of every item is name relative to the root of ISO or distribution kit, the second is name of local file. If the first subitem ends in /, the last component of local file name is appended. The last component of the second subitem may contain '*'; if so, it will be expanded according to usual rules, but without matching directories. Tup does not allow a direct dependency on a file that is generated in a directory other than where Tupfile.lua is and its children. Most files are generated in the directory with Tupfile.lua; for other files, the item should contain a named subitem "group=path/" and the file should be put in . --]] extra_files = { {"/", "common/distr_data/autorun.inf"}, {"/", "common/distr_data/KolibriOS_icon.ico"}, {"Docs/stack.txt", "../kernel/trunk/docs/stack.txt"}, {"HD_Load/9x2klbr/", "common/HD_load/9x2klbr/LDKLBR.VXD"}, {"HD_Load/MeOSLoad/", PROGS .. "/hd_load/meosload/AUTOEXEC.BAT"}, {"HD_Load/MeOSLoad/", PROGS .. "/hd_load/meosload/CONFIG.SYS"}, {"HD_Load/MeOSLoad/", PROGS .. "/hd_load/meosload/L_readme.txt"}, {"HD_Load/MeOSLoad/", PROGS .. "/hd_load/meosload/L_readme_Win.txt"}, {"HD_Load/mtldr/", PROGS .. "/hd_load/mtldr/vista_install.bat"}, {"HD_Load/mtldr/", PROGS .. "/hd_load/mtldr/vista_remove.bat"}, {"HD_Load/", "common/HD_load/memdisk"}, {"HD_Load/USB_boot_old/", PROGS .. "/hd_load/usb_boot_old/usb_boot.rtf"}, {"HD_Load/USB_boot_old/", PROGS .. "/hd_load/usb_boot_old/usb_boot_866.txt"}, {"HD_Load/USB_boot_old/", PROGS .. "/hd_load/usb_boot_old/usb_boot_1251.txt"}, {"kolibrios/3D/info3ds/INFO3DS.INI", PROGS .. "/develop/info3ds/info3ds.ini"}, {"kolibrios/3D/info3ds/OBJECTS.PNG", PROGS .. "/develop/info3ds/objects.png"}, {"kolibrios/3D/info3ds/TOOLBAR.PNG", PROGS .. "/develop/info3ds/toolbar.png"}, {"kolibrios/3D/info3ds/FONT8X9.BMP", PROGS .. "/fs/kfar/trunk/font8x9.bmp"}, {"kolibrios/3D/blocks/", PROGS .. "/bcc32/games/blocks/bin/*"}, {"kolibrios/3D/blocks/models/", PROGS .. "/bcc32/games/blocks/models/*"}, {"kolibrios/3D/md2view/", "common/3d/md2view/*"}, {"kolibrios/3D/md2view/md2_model/", "common/3d/md2view/md2_model/*"}, {"kolibrios/3D/voxel_editor/VOX_EDITOR.INI", PROGS .. "/media/voxel_editor/trunk/vox_editor.ini"}, {"kolibrios/3D/voxel_editor/HOUSE1.VOX", PROGS .. "/media/voxel_editor/trunk/house1.vox"}, {"kolibrios/3D/voxel_editor/HOUSE2.VOX", PROGS .. "/media/voxel_editor/trunk/house2.vox"}, {"kolibrios/3D/voxel_editor/SQUIRREL.VOX", PROGS .. "/media/voxel_editor/trunk/squirrel.vox"}, {"kolibrios/3D/voxel_utilites/VOX_MOVER.INI" , PROGS .. "/media/voxel_editor/utilites/vox_mover.ini"}, {"kolibrios/3D/FONT8X9.BMP", PROGS .. "/fs/kfar/trunk/font8x9.bmp"}, {"kolibrios/3D/TOOLB_1.PNG", PROGS .. "/develop/libraries/TinyGL/asm_fork/examples/toolb_1.png"}, {"kolibrios/3D/TEST_GLU1", PROGS .. "/develop/libraries/TinyGL/asm_fork/examples/test_glu1"}, {"kolibrios/3D/TEST_GLU2", PROGS .. "/develop/libraries/TinyGL/asm_fork/examples/test_glu2"}, {"kolibrios/3D/TEXT_2.PNG", PROGS .. "/develop/libraries/TinyGL/asm_fork/examples/text_2.png"}, {"kolibrios/demos/ak47.lif", "common/demos/ak47.lif"}, {"kolibrios/demos/life2", "common/demos/life2"}, {"kolibrios/demos/relay.lif", "common/demos/relay.lif"}, {"kolibrios/demos/rpento.lif", "common/demos/rpento.lif"}, {"kolibrios/develop/c--/c--.elf", PROGS .. "/cmm/c--/c--.elf"}, {"kolibrios/develop/c--/c--.exe", PROGS .. "/cmm/c--/c--.exe"}, {"kolibrios/develop/c--/c--.ini", PROGS .. "/cmm/c--/c--.ini"}, {"kolibrios/develop/c--/manual_c--.htm", PROGS .. "/cmm/c--/manual_c--.htm"}, {"kolibrios/develop/fpc/", "common/develop/fpc/*"}, {"kolibrios/develop/fpc/examples/", PROGS .. "/develop/fp/examples/src/*"}, {"kolibrios/develop/fpc/examples/build.sh", "common/develop/fpc/build.sh"}, {"kolibrios/develop/oberon07/", PROGS .. "/develop/oberon07/*"}, {"kolibrios/develop/oberon07/doc/", PROGS .. "/develop/oberon07/doc/*"}, {"kolibrios/develop/oberon07/lib/KolibriOS/", PROGS .. "/develop/oberon07/lib/KolibriOS/*"}, {"kolibrios/develop/oberon07/samples/", PROGS .. "/develop/oberon07/samples/*"}, {"kolibrios/develop/tcc/", PROGS .. "/develop/ktcc/trunk/*"}, -- {"kolibrios/develop/tcc/", PROGS .. "/develop/ktcc/trunk/bin/tcc"}, {"kolibrios/develop/tcc/lib/", PROGS .. "/develop/ktcc/trunk/bin/lib/*"}, {"kolibrios/develop/tcc/include/", PROGS .. "/develop/ktcc/trunk/libc.obj/include/*"}, {"kolibrios/develop/tcc/include/clayer/", PROGS .. "/develop/ktcc/trunk/libc.obj/include/clayer/*"}, {"kolibrios/develop/tcc/include/cryptal/", PROGS .. "/develop/ktcc/trunk/libc.obj/include/cryptal/*"}, {"kolibrios/develop/tcc/include/sys/", PROGS .. "/develop/ktcc/trunk/libc.obj/include/sys/*"}, {"kolibrios/develop/tcc/include/SDL/", "../contrib/sdk/sources/SDL-1.2.2_newlib/include/*"}, -- {"kolibrios/develop/tcc/include/net/", PROGS .. "/develop/ktcc/trunk/libc/include/net/*"}, -- {"kolibrios/develop/tcc/include/tinygl/", PROGS .. "/develop/ktcc/trunk/libc.obj/include/tinygl/*"}, {"kolibrios/develop/tcc/samples/", PROGS .. "/develop/ktcc/trunk/libc.obj/samples/*.c"}, {"kolibrios/develop/tcc/samples/", PROGS .. "/develop/ktcc/trunk/libc.obj/samples/*.sh"}, {"kolibrios/develop/tcc/samples/clayer/", PROGS .. "/develop/ktcc/trunk/libc.obj/samples/clayer/*"}, -- {"kolibrios/develop/tcc/samples/net/", PROGS .. "/develop/ktcc/trunk/samples/net/*"}, -- {"kolibrios/develop/tcc/samples/tinygl/", PROGS .. "/develop/ktcc/trunk/samples/tinygl/*"}, {"kolibrios/develop/utils/SPEDump", PROGS .. "/develop/SPEDump/SPEDump.kex"}, {"kolibrios/emul/", "common/emul/*"}, {"kolibrios/emul/dosbox/", "common/emul/DosBox/*"}, {"kolibrios/emul/e80/readme.txt", PROGS .. "/emulator/e80/trunk/readme.txt"}, {"kolibrios/emul/e80/keyboard.png", PROGS .. "/emulator/e80/trunk/keyboard.png"}, {"kolibrios/emul/fceu/fceu", PROGS .. "/emulator/fceu/fceu"}, {"kolibrios/emul/fceu/FCEU ReadMe.txt", PROGS .. "/emulator/fceu/FCEU ReadMe.txt"}, {"kolibrios/emul/chip8/chip8", PROGS .. "/emulator/chip8/chip8"}, {"kolibrios/emul/chip8/readme.txt", PROGS .. "/emulator/chip8/readme.txt"}, {"kolibrios/emul/chip8/roms/", PROGS .. "/emulator/chip8/roms/*"}, {"kolibrios/emul/kwine/kwine", PROGS .. "/emulator/kwine/bin/kwine"}, {"kolibrios/emul/kwine/lib/", PROGS .. "/emulator/kwine/bin/lib/*"}, {"kolibrios/emul/uarm/", "common/emul/uarm/*"}, {"kolibrios/emul/zsnes/", "common/emul/zsnes/*"}, {"kolibrios/games/BabyPainter", "common/games/BabyPainter"}, {"kolibrios/games/bomber/ackack.bmp", PROGS .. "/games/bomber/ackack.bmp"}, {"kolibrios/games/bomber/bomb.bmp", PROGS .. "/games/bomber/bomb.bmp"}, {"kolibrios/games/bomber/plane.bmp", PROGS .. "/games/bomber/plane.bmp"}, {"kolibrios/games/bomber/tile.bmp", PROGS .. "/games/bomber/tile.bmp"}, {"kolibrios/games/doom1/", "common/games/doom/*"}, {"kolibrios/games/fara/fara.gfx", "common/games/fara.gfx"}, {"kolibrios/games/jumpbump/", "common/games/jumpbump/*"}, {"kolibrios/games/knight", "common/games/knight"}, {"kolibrios/games/KosChess/", "common/games/KosChess/*"}, {"kolibrios/games/KosChess/images/", "common/games/KosChess/images/*"}, {"kolibrios/games/LaserTank/", "common/games/LaserTank/*"}, {"kolibrios/games/lrl/", "common/games/lrl/*"}, {"kolibrios/games/mun/data/", "common/games/mun/data/*"}, {"kolibrios/games/mun/libc.dll", "common/games/mun/libc.dll"}, {"kolibrios/games/mun/mun", "common/games/mun/mun"}, {"kolibrios/games/pig/", "common/games/pig/*"}, {"kolibrios/games/soko/", "common/games/soko/*"}, {"kolibrios/games/fridge/", "common/games/fridge/*"}, {"kolibrios/games/the_bus/menu.png", PROGS .. "/cmm/the_bus/menu.png"}, {"kolibrios/games/the_bus/objects.png", PROGS .. "/cmm/the_bus/objects.png"}, {"kolibrios/games/the_bus/road.png", PROGS .. "/cmm/the_bus/road.png"}, {"kolibrios/grafx2/fonts/", "common/media/grafx2/fonts/*"}, {"kolibrios/grafx2/scripts/", "common/media/grafx2/scripts/libs/*"}, {"kolibrios/grafx2/scripts/libs/", "common/media/grafx2/scripts/*"}, {"kolibrios/grafx2/skins/", "common/media/grafx2/skins/*"}, {"kolibrios/grafx2/", "common/media/grafx2/*"}, {"kolibrios/speech/", "common/media/speech/*"}, {"kolibrios/drivers/drvinf.ini", "common/drivers/drvinf.ini"}, {"kolibrios/drivers/ahci/", "common/drivers/ahci/*"}, {"kolibrios/drivers/acpi/", "common/drivers/acpi/*"}, {"kolibrios/drivers/atikms/", "common/drivers/atikms/*"}, {"kolibrios/drivers/i915/", "common/drivers/i915/*"}, {"kolibrios/drivers/test/", "common/drivers/test/*"}, {"kolibrios/drivers/vmware/", "common/drivers/vmware/*"}, {"kolibrios/KolibriNext/", "common/KolibriNext/*"}, {"kolibrios/KolibriNext/settings/", "common/KolibriNext/settings/*"}, {"kolibrios/lib/avcodec-56.dll", "common/lib/avcodec-56.dll"}, {"kolibrios/lib/avdevice-56.dll", "common/lib/avdevice-56.dll"}, {"kolibrios/lib/avformat-56.dll", "common/lib/avformat-56.dll"}, {"kolibrios/lib/swscale-3.dll", "common/lib/swscale-3.dll"}, {"kolibrios/lib/avutil-54.dll", "common/lib/avutil-54.dll"}, {"kolibrios/lib/cairo2.dll", "common/lib/cairo2.dll"}, {"kolibrios/lib/freetype.dll", "common/lib/freetype.dll"}, {"kolibrios/lib/i965-video.dll", "common/lib/i965-video.dll"}, {"kolibrios/lib/libdrm.dll", "common/lib/libdrm.dll"}, {"kolibrios/lib/libegl.dll", "common/lib/libegl.dll"}, {"kolibrios/lib/libeglut.dll", "common/lib/libeglut.dll"}, {"kolibrios/lib/libGL.dll", "common/lib/libGL.dll"}, {"kolibrios/lib/libjpeg.dll", "common/lib/libjpeg.dll"}, {"kolibrios/lib/libpng16.dll", "common/lib/libpng16.dll"}, {"kolibrios/lib/libva.dll", "common/lib/libva.dll"}, {"kolibrios/lib/libz.dll", "common/lib/libz.dll"}, {"kolibrios/lib/osmesa.dll", "common/lib/osmesa.dll"}, {"kolibrios/lib/pixlib-gl.dll", "common/lib/pixlib-gl.dll"}, {"kolibrios/lib/pixman-1.dll", "common/lib/pixman-1.dll"}, {"kolibrios/lib/swresample-1.dll", "common/lib/swresample-1.dll"}, {"kolibrios/lib/i915_dri.drv", "common/lib/i915_dri.drv"}, {"kolibrios/media/fplay", "common/media/fplay"}, {"kolibrios/media/fplay_run", "common/media/fplay_run"}, {"kolibrios/media/minimp3", "common/media/minimp3"}, {"kolibrios/media/updf", "common/media/updf"}, {"kolibrios/media/vttf", "common/media/vttf"}, {"kolibrios/media/beat/Beat", PROGS .. "/media/Beat/Beat"}, {"kolibrios/media/beat/Beep1.raw", PROGS .. "/media/Beat/Beep1.raw"}, {"kolibrios/media/beat/Beep2.raw", PROGS .. "/media/Beat/Beep2.raw"}, {"kolibrios/media/beat/PlayNote", PROGS .. "/media/Beat/PlayNote/PlayNote"}, {"kolibrios/media/beat/Readme-en.txt", PROGS .. "/media/Beat/Readme-en.txt"}, {"kolibrios/media/beat/Readme-ru.txt", PROGS .. "/media/Beat/Readme-ru.txt"}, {"kolibrios/media/zsea/zsea.ini", PROGS .. "/media/zsea/zSea.ini"}, {"kolibrios/media/zsea/buttons/buttons.png", PROGS .. "/media/zsea/buttons.png"}, {"kolibrios/netsurf/netsurf", "common/network/netsurf/netsurf"}, {"kolibrios/netsurf/res/", "common/network/netsurf/res/*"}, {"kolibrios/res/skins/", "../skins/authors.txt"}, {"kolibrios/res/templates/", "common/templates/*"}, {"kolibrios/res/templates/", PROGS .. "/emulator/e80/trunk/games/*"}, {"kolibrios/res/templates/NES/", "common/templates/NES/*"}, {"kolibrios/res/wallpapers/", "common/wallpapers/*"}, {"kolibrios/res/system/", build_type .. "/settings/kolibri.lbl"}, {"kolibrios/utils/man2html", "common/utils/MAN2HTML"}, {"kolibrios/utils/vmode", "common/vmode"}, {"kolibrios/utils/texture", "common/utils/texture"}, {"kolibrios/utils/cnc_editor/cnc_editor", PROGS .. "/other/cnc_editor/cnc_editor"}, {"kolibrios/utils/cnc_editor/kolibri.NC", PROGS .. "/other/cnc_editor/kolibri.NC"}, {"kolibrios/utils/kfm/kfm.ini", "common/File Managers/kfm.ini"}, {"kolibrios/utils/kfm/kfm_keys_eng.txt", PROGS .. "/fs/kfm/trunk/docs/english/kfm_keys.txt"}, {"kolibrios/utils/kfm/kfm_keys_rus.txt", PROGS .. "/fs/kfm/trunk/docs/russian/dos_kolibri/kfm_keys.txt"}, {"kolibrios/utils/NDN/", "common/File Managers/ndn/*"}, {"kolibrios/utils/NDN/COLORS/", "common/File Managers/ndn/COLORS/*"}, {"kolibrios/utils/NDN/XLT/", "common/File Managers/ndn/XLT/*"}, {"kolibrios/utils/tedit/t_edit.ini", PROGS .. "/other/t_edit/t_edit.ini"}, {"kolibrios/utils/tedit/info/ASM.SYN", PROGS .. "/other/t_edit/info/asm.syn"}, {"kolibrios/utils/tedit/info/CPP_CLA.SYN", PROGS .. "/other/t_edit/info/cpp_kol_cla.syn"}, {"kolibrios/utils/tedit/info/CPP_DAR.SYN", PROGS .. "/other/t_edit/info/cpp_kol_dar.syn"}, {"kolibrios/utils/tedit/info/CPP_DEF.SYN", PROGS .. "/other/t_edit/info/cpp_kol_def.syn"}, {"kolibrios/utils/tedit/info/DEFAULT.SYN", PROGS .. "/other/t_edit/info/default.syn"}, {"kolibrios/utils/tedit/info/HTML.SYN", PROGS .. "/other/t_edit/info/html.syn"}, {"kolibrios/utils/tedit/info/INI.SYN", PROGS .. "/other/t_edit/info/ini_files.syn"}, } if build_type == "rus" then tup.append_table(extra_files, { {"Docs/cp866/config.txt", build_type .. "/docs/CONFIG.TXT"}, {"Docs/cp866/gnu.txt", build_type .. "/docs/GNU.TXT"}, {"Docs/cp866/history.txt", build_type .. "/docs/HISTORY.TXT"}, {"Docs/cp866/hot_keys.txt", build_type .. "/docs/HOT_KEYS.TXT"}, {"Docs/cp866/install.txt", build_type .. "/docs/INSTALL.TXT"}, {"Docs/cp866/readme.txt", build_type .. "/docs/README.TXT"}, {"Docs/cp866/sysfuncr.txt", PROGS .. "/system/docpack/trunk/SYSFUNCR.TXT"}, {"Docs/cp1251/config.txt", build_type .. "/docs/CONFIG.WIN.TXT", cp1251_from = build_type .. "/docs/CONFIG.TXT"}, {"Docs/cp1251/gnu.txt", build_type .. "/docs/GNU.WIN.TXT", cp1251_from = build_type .. "/docs/GNU.TXT"}, {"Docs/cp1251/history.txt", build_type .. "/docs/HISTORY.WIN.TXT", cp1251_from = build_type .. "/docs/HISTORY.TXT"}, {"Docs/cp1251/hot_keys.txt", build_type .. "/docs/HOT_KEYS.WIN.TXT", cp1251_from = build_type .. "/docs/HOT_KEYS.TXT"}, {"Docs/cp1251/install.txt", build_type .. "/docs/INSTALL.WIN.TXT", cp1251_from = build_type .. "/docs/INSTALL.TXT"}, {"Docs/cp1251/readme.txt", build_type .. "/docs/README.WIN.TXT", cp1251_from = build_type .. "/docs/README.TXT"}, {"Docs/cp1251/sysfuncr.txt", build_type .. "/docs/SYSFUNCR.WIN.TXT", cp1251_from = PROGS .. "/system/docpack/trunk/SYSFUNCR.TXT"}, {"HD_Load/9x2klbr/", PROGS .. "/hd_load/9x2klbr/readme_dos.txt"}, {"HD_Load/9x2klbr/", PROGS .. "/hd_load/9x2klbr/readme_win.txt"}, {"HD_Load/mtldr/", PROGS .. "/hd_load/mtldr/install.txt"}, {"HD_Load/USB_Boot/", PROGS .. "/hd_load/usb_boot/readme.txt"}, {"kolibrios/games/ataka", "common/games/ataka/ataka_ru"}, {"kolibrios/games/Dungeons/Resources/Textures/Environment/", PROGS .. "/games/Dungeons/Resources/Textures/Environment/*"}, {"kolibrios/games/Dungeons/Resources/Textures/Objects/", PROGS .. "/games/Dungeons/Resources/Textures/Objects/*"}, {"kolibrios/games/Dungeons/Resources/Textures/HUD/", PROGS .. "/games/Dungeons/Resources/Textures/HUD/*"}, {"kolibrios/games/Dungeons/Resources/Textures/", PROGS .. "/games/Dungeons/Resources/Textures/Licenses.txt"}, {"kolibrios/games/Dungeons/", PROGS .. "/games/Dungeons/readme_ru.txt"}, {"kolibrios/games/sstartrek/SStarTrek", "common/games/sstartrek/SStarTrek_ru"}, {"kolibrios/games/WHOWTBAM/", build_type .. "/games/whowtbam"}, {"kolibrios/games/WHOWTBAM/", build_type .. "/games/appdata.dat"}, {"kolibrios/media/zsea/zsea_keys.txt", PROGS .. "/media/zsea/Docs/zSea_keys_rus.txt"}, {"kolibrios/res/guide/", build_type .. "/docs/guide/*"}, }) else tup.append_table(extra_files, { {"Docs/config.txt", build_type .. "/docs/CONFIG.TXT"}, {"Docs/copying.txt", build_type .. "/docs/COPYING.TXT"}, {"Docs/hot_keys.txt", build_type .. "/docs/HOT_KEYS.TXT"}, {"Docs/install.txt", build_type .. "/docs/INSTALL.TXT"}, {"Docs/readme.txt", build_type .. "/docs/README.TXT"}, {"Docs/sysfuncs.txt", PROGS .. "/system/docpack/trunk/SYSFUNCS.TXT"}, {"HD_Load/9x2klbr/", PROGS .. "/hd_load/9x2klbr/readme.txt"}, {"HD_Load/mtldr/install.txt", PROGS .. "/hd_load/mtldr/install_eng.txt"}, {"HD_Load/USB_Boot/readme.txt", PROGS .. "/hd_load/usb_boot/readme_eng.txt"}, {"kolibrios/games/ataka", "common/games/ataka/ataka_en"}, {"kolibrios/games/sstartrek/SStarTrek", "common/games/sstartrek/SStarTrek_en"}, {"kolibrios/media/zsea/zsea_keys.txt", PROGS .. "/media/zsea/Docs/zSea_keys_eng.txt"}, }) end --[[ Files to be included in distribution kit outside of kolibri.img, but not kolibri.iso. Same syntax as extra_files. ]]-- if build_type == "rus" then distr_extra_files = { {"/readme_dos.txt", build_type .. "/distr_data/readme_dos_distr.txt"}, {"/readme.txt", build_type .. "/distr_data/readme_distr.txt", cp1251_from = build_type .. "/distr_data/readme_dos_distr.txt"}, } else distr_extra_files = { {"/readme.txt", build_type .. "/distr_data/readme_distr.txt"}, } end --[[ Files to be included in kolibri.iso outside of kolibri.img, but not distribution kit. Same syntax as extra_files. ]]-- if build_type == "rus" then iso_extra_files = { {"/readme_dos.txt", build_type .. "/distr_data/readme_dos.txt"}, {"/readme.txt", build_type .. "/distr_data/readme.txt", cp1251_from = build_type .. "/distr_data/readme_dos.txt"}, } else iso_extra_files = { {"/readme.txt", build_type .. "/distr_data/readme.txt"}, } end -- Programs that require FASM to compile. if tup.getconfig('NO_FASM') ~= 'full' then tup.append_table(img_files, { {"KERNEL.MNT", "../kernel/trunk/kernel.mnt"}, {"@DOCKY", PROGS .. "/system/docky/trunk/docky"}, {"@HOTANGLES", PROGS .. "/other/ha/HOTANGLES"}, {"@ICON", PROGS .. "/system/icon_new/icon"}, {"@MENU", PROGS .. "/system/menu/trunk/menu"}, {"@NOTIFY", PROGS .. "/system/notify3/notify"}, {"@OPEN", PROGS .. "/system/open/open"}, {"@TASKBAR", PROGS .. "/system/taskbar/trunk/TASKBAR"}, {"@SS", PROGS .. "/system/scrsaver/scrsaver"}, {"@VOLUME", PROGS .. "/media/volume/volume"}, {"HACONFIG", PROGS .. "/other/ha/HACONFIG"}, {"APM", PROGS .. "/system/apm/apm"}, {"CALC", PROGS .. "/other/calc/trunk/calc"}, {"CALENDAR", PROGS .. "/system/calendar/trunk/calendar"}, {"COLRDIAL", PROGS .. "/system/colrdial/color_dialog"}, {"CROPFLAT", PROGS .. "/system/cropflat/cropflat"}, {"CPU", PROGS .. "/system/cpu/trunk/cpu"}, {"CPUID", PROGS .. "/testing/cpuid/trunk/CPUID"}, {"DOCPACK", PROGS .. "/system/docpack/trunk/docpack"}, {"DEFAULT.SKN", "../skins/Leency/Shkvorka/Shkvorka.skn"}, {"DISPTEST", PROGS .. "/testing/disptest/trunk/disptest"}, {"END", PROGS .. "/system/end/light/end"}, {"ESKIN", PROGS .. "/system/eskin/trunk/eskin"}, {"FSPEED", PROGS .. "/testing/fspeed/fspeed"}, {"GMON", PROGS .. "/system/gmon/gmon"}, {"HDD_INFO", PROGS .. "/system/hdd_info/trunk/hdd_info"}, {"KBD", PROGS .. "/testing/kbd/trunk/kbd"}, {"KPACK", PROGS .. "/other/kpack/trunk/kpack"}, {"LAUNCHER", PROGS .. "/system/launcher/trunk/launcher"}, {"LOADDRV", PROGS .. "/system/loaddrv/loaddrv"}, {"MAGNIFY", PROGS .. "/demos/magnify/trunk/magnify"}, {"MGB", PROGS .. "/testing/mgb/trunk/mgb"}, {"MOUSEMUL", PROGS .. "/system/mousemul/trunk/mousemul"}, {"MADMOUSE", PROGS .. "/other/madmouse/madmouse"}, {"MYKEY", PROGS .. "/system/MyKey/trunk/MyKey"}, {"PCIDEV", PROGS .. "/testing/pcidev/trunk/PCIDEV"}, {"RDSAVE", PROGS .. "/system/rdsave/trunk/rdsave"}, {"RTFREAD", PROGS .. "/other/rtfread/trunk/rtfread"}, {"SEARCHAP", PROGS .. "/system/searchap/searchap"}, {"SCRSHOOT", PROGS .. "/media/scrshoot/scrshoot"}, {"SETUP", PROGS .. "/system/setup/trunk/setup"}, {"SKINCFG", PROGS .. "/system/skincfg/trunk/skincfg"}, {"TERMINAL", PROGS .. "/system/terminal/terminal"}, {"TEST", PROGS .. "/testing/protection/trunk/test"}, {"TINYPAD", PROGS .. "/develop/tinypad/trunk/tinypad"}, {"UNZ", PROGS .. "/fs/unz/unz"}, {"ZKEY", PROGS .. "/system/zkey/trunk/ZKEY"}, {"3D/3DWAV", PROGS .. "/demos/3dwav/trunk/3dwav"}, {"3D/CROWNSCR", PROGS .. "/demos/crownscr/trunk/crownscr"}, {"3D/3DCUBE2", PROGS .. "/demos/3dcube2/trunk/3DCUBE2"}, {"3D/FREE3D04", PROGS .. "/demos/free3d04/trunk/free3d04"}, {"3D/GEARS", PROGS .. "/develop/libraries/TinyGL/asm_fork/examples/gears"}, {"3D/RAY", PROGS .. "/demos/ray/ray"}, {"3D/VIEW3DS", PROGS .. "/demos/view3ds/view3ds"}, {"DEMOS/BCDCLK", PROGS .. "/demos/bcdclk/trunk/bcdclk"}, {"DEMOS/EYES", PROGS .. "/demos/eyes/trunk/eyes"}, {"DEMOS/FIREWORK", PROGS .. "/demos/firework/trunk/firework"}, {"DEMOS/MOVBACK", PROGS .. "/demos/movback/trunk/movback"}, {"DEMOS/PLASMA", PROGS .. "/demos/plasma/trunk/plasma"}, {"DEMOS/SPIRAL", PROGS .. "/demos/spiral/spiral"}, {"DEMOS/TINYFRAC", PROGS .. "/demos/tinyfrac/trunk/tinyfrac"}, {"DEMOS/TRANTEST", PROGS .. "/demos/trantest/trunk/trantest"}, {"DEMOS/TUBE", PROGS .. "/demos/tube/trunk/tube"}, {"DEMOS/UNVWATER", PROGS .. "/demos/unvwater/trunk/unvwater"}, {"DEMOS/WEB", PROGS .. "/demos/web/trunk/web"}, {"DEMOS/ZEROLINE", PROGS .. "/demos/zeroline/trunk/zeroline"}, {"DEVELOP/ASCIIVJU", PROGS .. "/develop/asciivju/trunk/asciivju"}, {"DEVELOP/BOARD", PROGS .. "/system/board/trunk/board"}, {"DEVELOP/CEDIT", PROGS .. "/develop/cedit/CEDIT"}, {"DEVELOP/COBJ", PROGS .. "/develop/cObj/trunk/cObj"}, {"DEVELOP/ENTROPYV", PROGS .. "/develop/entropyview/entropyview"}, {"DEVELOP/FASM", PROGS .. "/develop/fasm/1.73/fasm"}, {"DEVELOP/H2D2B", PROGS .. "/develop/h2d2b/trunk/h2d2b"}, {"DEVELOP/HEED", PROGS .. "/develop/heed/trunk/heed"}, {"DEVELOP/KEYASCII", PROGS .. "/develop/keyascii/trunk/keyascii"}, {"DEVELOP/MTDBG", PROGS .. "/develop/mtdbg/mtdbg"}, {"DEVELOP/SCANCODE", PROGS .. "/develop/scancode/trunk/scancode"}, {"DEVELOP/EXAMPLES/CIRCLE", PROGS .. "/develop/examples/circle/trunk/circle"}, {"DEVELOP/EXAMPLES/COLORREF", PROGS .. "/demos/colorref/trunk/colorref"}, {"DEVELOP/EXAMPLES/CONGET", PROGS .. "/develop/libraries/console_coff/examples/test_gets"}, {"DEVELOP/EXAMPLES/CSLIDE", PROGS .. "/demos/cslide/trunk/cslide"}, {"DEVELOP/EXAMPLES/THREAD", PROGS .. "/develop/examples/thread/trunk/thread"}, {"DEVELOP/EXAMPLES/USE_MB", PROGS .. "/demos/use_mb/use_mb"}, {"File Managers/KFAR", PROGS .. "/fs/kfar/trunk/kfar"}, {"File Managers/OPENDIAL", PROGS .. "/fs/opendial/opendial"}, {"GAMES/15", PROGS .. "/games/15/trunk/15"}, {"GAMES/FREECELL", PROGS .. "/games/freecell/freecell"}, {"GAMES/GOMOKU", PROGS .. "/games/gomoku/trunk/gomoku"}, {"GAMES/LIGHTS", PROGS .. "/games/sq_game/trunk/SQ_GAME"}, {"GAMES/LINES", PROGS .. "/games/lines/lines"}, {"GAMES/MSQUARE", PROGS .. "/games/MSquare/trunk/MSquare"}, {"GAMES/PIPES", PROGS .. "/games/pipes/pipes"}, {"GAMES/PONG", PROGS .. "/games/pong/trunk/pong"}, {"GAMES/PONG3", PROGS .. "/games/pong3/trunk/pong3"}, {"GAMES/RSQUARE", PROGS .. "/games/rsquare/trunk/rsquare"}, {"GAMES/SNAKE", PROGS .. "/games/snake/trunk/snake"}, {"GAMES/SUDOKU", PROGS .. "/games/sudoku/trunk/sudoku"}, {"GAMES/SW", PROGS .. "/games/sw/trunk/sw"}, {"GAMES/TANKS", PROGS .. "/games/tanks/trunk/tanks"}, {"GAMES/TETRIS", PROGS .. "/games/tetris/trunk/tetris"}, {"LIB/ARCHIVER.OBJ", PROGS .. "/fs/kfar/trunk/kfar_arc/kfar_arc.obj"}, {"LIB/BOX_LIB.OBJ", PROGS .. "/develop/libraries/box_lib/trunk/box_lib.obj"}, {"LIB/BUF2D.OBJ", PROGS .. "/develop/libraries/buf2d/trunk/buf2d.obj"}, {"LIB/CONSOLE.OBJ", PROGS .. "/develop/libraries/console_coff/console.obj"}, {"LIB/CNV_PNG.OBJ", PROGS .. "/media/zsea/plugins/png/cnv_png.obj"}, {"LIB/DLL.OBJ", PROGS .. "/develop/libraries/dll/dll.obj"}, {"LIB/HTTP.OBJ", PROGS .. "/develop/libraries/http/http.obj"}, {"LIB/LIBCRASH.OBJ", PROGS .. "/develop/libraries/libcrash/libcrash.obj"}, {"LIB/LIBGFX.OBJ", PROGS .. "/develop/libraries/libs-dev/libgfx/libgfx.obj"}, {"LIB/LIBIMG.OBJ", PROGS .. "/develop/libraries/libs-dev/libimg/libimg.obj"}, {"LIB/LIBINI.OBJ", PROGS .. "/develop/libraries/libs-dev/libini/libini.obj"}, {"LIB/LIBIO.OBJ", PROGS .. "/develop/libraries/libs-dev/libio/libio.obj"}, {"LIB/MSGBOX.OBJ", PROGS .. "/develop/libraries/msgbox/msgbox.obj"}, {"LIB/NETWORK.OBJ", PROGS .. "/develop/libraries/network/network.obj"}, {"LIB/PROC_LIB.OBJ", PROGS .. "/develop/libraries/proc_lib/trunk/proc_lib.obj"}, {"LIB/RASTERWORKS.OBJ", PROGS .. "/develop/libraries/fontRasterWorks(unicode)/RasterWorks.obj"}, {"LIB/SORT.OBJ", PROGS .. "/develop/libraries/sorter/sort.obj"}, {"LIB/TINYGL.OBJ", PROGS .. "/develop/libraries/TinyGL/asm_fork/tinygl.obj"}, {"MEDIA/ANIMAGE", PROGS .. "/media/animage/trunk/animage"}, {"MEDIA/KIV", PROGS .. "/media/kiv/trunk/kiv"}, {"MEDIA/LISTPLAY", PROGS .. "/media/listplay/trunk/listplay"}, {"MEDIA/MIDAMP", PROGS .. "/media/midamp/trunk/midamp"}, {"MEDIA/MP3INFO", PROGS .. "/media/mp3info/mp3info"}, {"MEDIA/PALITRA", PROGS .. "/media/palitra/trunk/palitra"}, {"MEDIA/PIANO", PROGS .. "/media/piano/piano"}, {"MEDIA/STARTMUS", PROGS .. "/media/startmus/trunk/STARTMUS"}, {"NETWORK/PING", PROGS .. "/network/ping/ping"}, {"NETWORK/NETCFG", PROGS .. "/network/netcfg/netcfg"}, {"NETWORK/NETSTAT", PROGS .. "/network/netstat/netstat"}, {"NETWORK/NSINST", PROGS .. "/network/netsurf/nsinstall"}, {"NETWORK/NSLOOKUP", PROGS .. "/network/nslookup/nslookup"}, {"NETWORK/PASTA", PROGS .. "/network/pasta/pasta"}, {"NETWORK/SYNERGYC", PROGS .. "/network/synergyc/synergyc"}, {"NETWORK/SNTP", PROGS .. "/network/sntp/sntp"}, {"NETWORK/TELNET", PROGS .. "/network/telnet/telnet"}, {"NETWORK/@ZEROCONF", PROGS .. "/network/zeroconf/zeroconf"}, {"NETWORK/FTPC", PROGS .. "/network/ftpc/ftpc"}, {"NETWORK/FTPD", PROGS .. "/network/ftpd/ftpd"}, {"NETWORK/TFTPC", PROGS .. "/network/tftpc/tftpc"}, {"NETWORK/IRCC", PROGS .. "/network/ircc/ircc"}, {"NETWORK/DOWNLOADER", PROGS .. "/network/downloader/downloader"}, {"NETWORK/VNCC", PROGS .. "/network/vncc/vncc"}, {"DRIVERS/VIDINTEL.SYS", "../drivers/video/vidintel.sys"}, {"DRIVERS/3C59X.SYS", "../drivers/ethernet/3c59x.sys"}, {"DRIVERS/AR81XX.SYS", "../drivers/ethernet/ar81xx.sys"}, {"DRIVERS/DEC21X4X.SYS", "../drivers/ethernet/dec21x4x.sys"}, {"DRIVERS/FORCEDETH.SYS", "../drivers/ethernet/forcedeth.sys"}, {"DRIVERS/I8254X.SYS", "../drivers/ethernet/i8254x.sys"}, {"DRIVERS/I8255X.SYS", "../drivers/ethernet/i8255x.sys"}, {"DRIVERS/MTD80X.SYS", "../drivers/ethernet/mtd80x.sys"}, {"DRIVERS/PCNET32.SYS", "../drivers/ethernet/pcnet32.sys"}, {"DRIVERS/R6040.SYS", "../drivers/ethernet/R6040.sys"}, {"DRIVERS/RHINE.SYS", "../drivers/ethernet/rhine.sys"}, {"DRIVERS/RTL8029.SYS", "../drivers/ethernet/RTL8029.sys"}, {"DRIVERS/RTL8139.SYS", "../drivers/ethernet/RTL8139.sys"}, {"DRIVERS/RTL8169.SYS", "../drivers/ethernet/RTL8169.sys"}, {"DRIVERS/SIS900.SYS", "../drivers/ethernet/sis900.sys"}, {"DRIVERS/UHCI.SYS", "../drivers/usb/uhci.sys"}, {"DRIVERS/OHCI.SYS", "../drivers/usb/ohci.sys"}, {"DRIVERS/EHCI.SYS", "../drivers/usb/ehci.sys"}, {"DRIVERS/USBHID.SYS", "../drivers/usb/usbhid/usbhid.sys"}, {"DRIVERS/USBSTOR.SYS", "../drivers/usb/usbstor.sys"}, {"DRIVERS/RDC.SYS", "../drivers/video/rdc.sys"}, {"DRIVERS/COMMOUSE.SYS", "../drivers/mouse/commouse.sys"}, {"DRIVERS/PS2MOUSE.SYS", "../drivers/mouse/ps2mouse4d/trunk/ps2mouse.sys"}, {"DRIVERS/TMPDISK.SYS", "../drivers/disk/tmpdisk.sys"}, {"DRIVERS/HDAUDIO.SYS", "../drivers/audio/intel_hda/hdaudio.sys"}, {"DRIVERS/SB16.SYS", "../drivers/audio/sb16/sb16.sys"}, {"DRIVERS/SOUND.SYS", "../drivers/audio/sound.sys"}, {"DRIVERS/INFINITY.SYS", "../drivers/audio/infinity/infinity.sys"}, {"DRIVERS/AC97.SYS", "../drivers/audio/ac97.sys"}, {"DRIVERS/EMU10K1X.SYS", "../drivers/audio/emu10k1x.sys"}, {"DRIVERS/FM801.SYS", "../drivers/audio/fm801.sys"}, {"DRIVERS/VT823X.SYS", "../drivers/audio/vt823x.sys"}, {"DRIVERS/SIS.SYS", "../drivers/audio/sis.sys"}, }) tup.append_table(extra_files, { {"HD_Load/9x2klbr/", PROGS .. "/hd_load/9x2klbr/9x2klbr.exe"}, {"HD_Load/MeOSLoad/", PROGS .. "/hd_load/meosload/MeOSload.com"}, {"HD_Load/mtldr/", PROGS .. "/hd_load/mtldr/mtldr"}, {"HD_Load/", PROGS .. "/hd_load/mtldr_install/mtldr_install.exe"}, {"HD_Load/USB_Boot/", PROGS .. "/hd_load/usb_boot/BOOT_F32.BIN"}, {"HD_Load/USB_Boot/", PROGS .. "/hd_load/usb_boot/MTLD_F32"}, {"HD_Load/USB_Boot/", PROGS .. "/hd_load/usb_boot/inst.exe"}, {"HD_Load/USB_Boot/", PROGS .. "/hd_load/usb_boot/setmbr.exe"}, {"HD_Load/USB_boot_old/", PROGS .. "/hd_load/usb_boot_old/MeOSload.com"}, {"HD_Load/USB_boot_old/", PROGS .. "/hd_load/usb_boot_old/enable.exe"}, {"kolibrios/3D/3dsheart", PROGS .. "/demos/3dsheart/trunk/3dsheart"}, {"kolibrios/3D/flatwav", PROGS .. "/demos/flatwav/trunk/flatwav"}, {"kolibrios/3D/mos3de", PROGS .. "/demos/mos3de/mos3de"}, {"kolibrios/3D/info3ds/INFO3DS", PROGS .. "/develop/info3ds/info3ds"}, {"kolibrios/3D/textures1", PROGS .. "/develop/libraries/TinyGL/asm_fork/examples/textures1"}, {"kolibrios/3D/info3ds/INFO3DS_U", PROGS .. "/develop/info3ds/info3ds_u"}, {"kolibrios/3D/voxel_editor/VOXEL_EDITOR", PROGS .. "/media/voxel_editor/trunk/voxel_editor"}, {"kolibrios/3D/voxel_utilites/VOX_CREATOR" , PROGS .. "/media/voxel_editor/utilites/vox_creator"}, {"kolibrios/3D/voxel_utilites/VOX_MOVER" , PROGS .. "/media/voxel_editor/utilites/vox_mover"}, {"kolibrios/3D/voxel_utilites/VOX_TGL" , PROGS .. "/media/voxel_editor/utilites/vox_tgl"}, {"kolibrios/demos/buddhabrot", PROGS .. "/demos/buddhabrot/trunk/buddhabrot"}, {"kolibrios/demos/life3", PROGS .. "/games/life3/trunk/life3"}, {"kolibrios/demos/qjulia", PROGS .. "/demos/qjulia/trunk/qjulia"}, {"kolibrios/develop/utils/koldbg", PROGS .. "/develop/koldbg/koldbg"}, {"kolibrios/games/Almaz", PROGS .. "/games/almaz/almaz"}, {"kolibrios/games/arcanii", PROGS .. "/games/arcanii/trunk/arcanii"}, {"kolibrios/games/bomber/bomber", PROGS .. "/games/bomber/bomber"}, {"kolibrios/games/bomber/bomberdata.bin", PROGS .. "/games/bomber/sounds/bomberdata.bin"}, {"kolibrios/games/codemaster/binary_master", PROGS .. "/games/codemaster/binary_master"}, {"kolibrios/games/codemaster/hang_programmer", PROGS .. "/games/codemaster/hang_programmer"}, {"kolibrios/games/codemaster/kolibri_puzzle", PROGS .. "/games/codemaster/kolibri_puzzle"}, {"kolibrios/games/megamaze", PROGS .. "/games/megamaze/trunk/megamaze"}, {"kolibrios/games/invaders", PROGS .. "/games/invaders/invaders"}, {"kolibrios/games/phenix", PROGS .. "/games/phenix/trunk/phenix"}, {"kolibrios/games/soko/soko", PROGS .. "/games/soko/trunk/SOKO"}, {"kolibrios/media/img_transform", PROGS .. "/media/img_transform/img_transform"}, {"kolibrios/media/zsea/zsea", PROGS .. "/media/zsea/zSea"}, {"kolibrios/media/zsea/plugins/cnv_bmp.obj", PROGS .. "/media/zsea/plugins/bmp/cnv_bmp.obj"}, {"kolibrios/media/zsea/plugins/cnv_gif.obj", PROGS .. "/media/zsea/plugins/gif/cnv_gif.obj"}, {"kolibrios/media/zsea/plugins/cnv_jpeg.obj", PROGS .. "/media/zsea/plugins/jpeg/cnv_jpeg.obj"}, {"kolibrios/media/zsea/plugins/convert.obj", PROGS .. "/media/zsea/plugins/convert/convert.obj"}, {"kolibrios/media/zsea/plugins/rotate.obj", PROGS .. "/media/zsea/plugins/rotate/rotate.obj"}, {"kolibrios/media/zsea/plugins/scaling.obj", PROGS .. "/media/zsea/plugins/scaling/scaling.obj"}, {"kolibrios/utils/AMDtemp", PROGS .. "/system/amd_temp_view/AMDtemp"}, {"kolibrios/utils/calcplus", PROGS .. "/other/calcplus/calcplus"}, {"kolibrios/utils/kfm/kfm", PROGS .. "/fs/kfm/trunk/kfm"}, {"kolibrios/utils/tedit/t_edit.kex", PROGS .. "/other/t_edit/t_edit"}, }) -- For russian build, add russian-only programs. if build_type == "rus" then tup.append_table(img_files, { {"PERIOD", PROGS .. "/other/period/trunk/period"}, {"GAMES/KLAVISHA", PROGS .. "/games/klavisha/trunk/klavisha"}, {"DEVELOP/EXAMPLES/TESTCON2", PROGS .. "/develop/libraries/console_coff/examples/testcon2_rus"}, }) else tup.append_table(img_files, { {"DEVELOP/TESTCON2", PROGS .. "/develop/libraries/console_coff/examples/testcon2_eng"}, }) end if build_type == "rus" then tup.append_table(extra_files, { {"kolibrios/games/Dungeons/Dungeons", PROGS .. "/games/Dungeons/Dungeons"}, }) end end -- tup.getconfig('NO_FASM') ~= 'full' -- Programs that require NASM to compile. if tup.getconfig('NO_NASM') ~= 'full' then tup.append_table(img_files, { {"ACLOCK", PROGS .. "/demos/aclock/trunk/aclock"}, {"LOD", PROGS .. "/fs/lod/lod"}, {"TIMER", PROGS .. "/other/Timer/timer"}, {"TINFO", PROGS .. "/system/tinfo/tinfo"}, {"DEVELOP/MSTATE", PROGS .. "/develop/mstate/mstate"}, {"DEVELOP/GENFILES", PROGS .. "/testing/genfiles/GenFiles"}, {"GAMES/C4", PROGS .. "/games/c4/trunk/c4"}, {"MEDIA/FILLSCR", PROGS .. "/media/FillScr/fillscr"}, }) tup.append_table(extra_files, { }) end -- tup.getconfig('NO_NASM') ~= 'full' -- Programs that require JWASM to compile. if tup.getconfig('NO_JWASM') ~= 'full' then tup.append_table(img_files, { {"RUN", PROGS .. "/system/RunOD/1/RUN"}, {"LIB/INPUTBOX.OBJ", PROGS .. "/develop/libraries/InputBox/INPUTBOX.OBJ"}, }) end -- tup.getconfig('NO_JWASM') ~= 'full' -- Programs that require C-- to compile. if tup.getconfig('NO_CMM') ~= 'full' then tup.append_table(img_files, { {"@RESHARE", PROGS .. "/cmm/misc/reshare.com"}, {"APP_PLUS", PROGS .. "/cmm/app_plus/app_plus.com"}, {"EASYSHOT", PROGS .. "/cmm/misc/easyshot.com"}, {"MOUSECFG", PROGS .. "/cmm/mousecfg/mousecfg.com"}, {"BARSCFG", PROGS .. "/cmm/barscfg/barscfg.com"}, {"SYSPANEL", PROGS .. "/cmm/misc/software_widget.com"}, {"SYSMON", PROGS .. "/cmm/sysmon/sysmon.com"}, {"TMPDISK", PROGS .. "/cmm/tmpdisk/tmpdisk.com"}, {"DEVELOP/CLIPVIEW", PROGS .. "/cmm/clipview/clipview.com"}, {"DEVELOP/MENU", PROGS .. "/cmm/menu/menu.com"}, {"DEVELOP/PIPET", PROGS .. "/cmm/misc/pipet.com"}, {"File Managers/EOLITE", PROGS .. "/cmm/eolite/Eolite.com"}, {"File Managers/KFM2", PROGS .. "/cmm/misc/kfm2.com"}, {"KF_VIEW", PROGS .. "/cmm/kf_font_viewer/font_viewer.com"}, {"DEVELOP/DIFF", PROGS .. "/cmm/diff/diff.com"}, {"GAMES/CLICKS", PROGS .. "/games/clicks/trunk/clicks.com"}, {"GAMES/MBLOCKS", PROGS .. "/cmm/misc/mblocks.com"}, {"GAMES/FLOOD-IT", PROGS .. "/games/flood-it/trunk/flood-it.com"}, {"GAMES/MINE", PROGS .. "/games/mine/trunk/mine"}, {"GAMES/NUMBERS", PROGS .. "/games/FindNumbers/trunk/FindNumbers"}, {"MEDIA/PIXIE", PROGS .. "/cmm/pixie2/pixie.com"}, {"MEDIA/ICONEDIT", PROGS .. "/cmm/iconedit/iconedit.com"}, {"NETWORK/DL", PROGS .. "/cmm/downloader/dl.com"}, {"NETWORK/WEBVIEW", PROGS .. "/cmm/browser/WebView.com"}, }) tup.append_table(extra_files, { {"kolibrios/drivers/drvinst.kex", PROGS .. "/cmm/drvinst/drvinst.com"}, {"kolibrios/drivers/acpi/install.kex", PROGS .. "/cmm/misc/acpi_install.com"}, {"kolibrios/games/pig/pigex", PROGS .. "/cmm/examples/pigex.com"}, {"kolibrios/games/the_bus/the_bus", PROGS .. "/cmm/the_bus/the_bus.com"}, {"kolibrios/KolibriNext/install.kex", PROGS .. "/cmm/misc/install.com"}, {"kolibrios/utils/appearance", PROGS .. "/cmm/appearance/appearance.com"}, {"kolibrios/utils/dicty.kex", PROGS .. "/cmm/dicty/dicty.com"}, {"kolibrios/utils/notes", PROGS .. "/cmm/notes/notes.com"}, {"kolibrios/utils/osupdate", PROGS .. "/cmm/misc/osupdate.com"}, {"kolibrios/utils/quark", PROGS .. "/cmm/quark/quark.com"}, }) end -- tup.getconfig('NO_CMM') ~= 'full' -- Programs that require MSVC to compile. if tup.getconfig('NO_MSVC') ~= 'full' then tup.append_table(img_files, { {"GRAPH", PROGS .. "/other/graph/graph"}, {"TABLE", PROGS .. "/other/table/table"}, {"MEDIA/AC97SND", PROGS .. "/media/ac97snd/ac97snd.bin"}, {"GAMES/KOSILKA", PROGS .. "/games/kosilka/kosilka"}, {"GAMES/RFORCES", PROGS .. "/games/rforces/trunk/rforces"}, {"GAMES/XONIX", PROGS .. "/games/xonix/trunk/xonix"}, }) tup.append_table(extra_files, { {"kolibrios/games/fara/fara", PROGS .. "/games/fara/trunk/fara"}, {"kolibrios/games/LaserTank/LaserTank", PROGS .. "/games/LaserTank/trunk/LaserTank"}, }) end -- tup.getconfig('NO_MSVC') ~= 'full' -- Programs that require TCC to compile. if tup.getconfig('NO_TCC') ~= 'full' then tup.append_table(img_files, { {"NETWORK/WHOIS", PROGS .. "/network/whois/whois"}, {"SHELL", PROGS .. "/system/shell/shell"}, -- {"NETWORK/WEATHER", PROGS .. "/other/Weather/weather"}, }) tup.append_table(extra_files, { {"kolibrios/utils/thashview", PROGS .. "/other/TinyHashView/thashview"}, {"kolibrios/develop/TinyBasic/TinyBasic", PROGS .. "/develop/tinybasic-1.0.4/tinybasic"}, {"kolibrios/develop/TinyBasic/bas/", PROGS .. "/develop/tinybasic-1.0.4/bas/*"}, {"kolibrios/develop/TinyBasic/TinyBasic.man", PROGS .. "/develop/tinybasic-1.0.4/doc/tinybasic.man"}, {"kolibrios/utils/teatool", PROGS .. "/other/TEAtool/teatool"}, {"kolibrios/utils/passwordgen", PROGS .. "/other/PasswordGen/passwordgen"}, {"kolibrios/utils/kruler", PROGS .. "/other/kruler/kruler"}, {"kolibrios/media/qr_tool", PROGS .. "/media/qr_tool/qr_tool"}, {"kolibrios/utils/weather", PROGS .. "/other/Weather/weather"}, }) end -- tup.getconfig('NO_TCC') ~= 'full' -- Programs that require GCC to compile. if tup.getconfig('NO_GCC') ~= 'full' then tup.append_table(img_files, { {"GAMES/REVERSI", PROGS .. "/games/reversi/trunk/reversi"}, {"LIB/BASE64.OBJ", PROGS .. "/develop/libraries/base64/base64.obj"}, {"LIB/LIBC.OBJ", PROGS .. "/develop/ktcc/trunk/libc.obj/source/libc.obj"}, {"LIB/ICONV.OBJ", PROGS .. "/develop/libraries/iconv/iconv.obj"}, -- {"LIB/MTAR.OBJ", PROGS .. "/develop/libraries/microtar/mtar.obj"}, }) tup.append_table(extra_files, { -- {"kolibrios/3D/cubeline", PROGS .. "/demos/cubeline/trunk/cubeline"}, {"kolibrios/emul/e80/e80", PROGS .. "/emulator/e80/trunk/e80"}, {"kolibrios/emul/uarm/", "../contrib/other/uarm/uARM"}, {"kolibrios/games/2048", PROGS .. "/games/2048/2048"}, {"kolibrios/games/checkers", PROGS .. "/games/checkers/trunk/checkers"}, {"kolibrios/games/donkey", PROGS .. "/games/donkey/donkey"}, {"kolibrios/games/heliothryx", PROGS .. "/games/heliothryx/heliothryx"}, {"kolibrios/games/marblematch3", PROGS .. "/games/marblematch3/marblematch3"}, {"kolibrios/games/nsider", PROGS .. "/games/nsider/nsider"}, {"kolibrios/games/quake/", "common/games/quake/*"}, -- not really gcc, but no sense without sdlquake {"kolibrios/games/quake/", "../contrib/other/sdlquake-1.0.9/sdlquake"}, {"kolibrios/games/fridge/", PROGS .. "/games/fridge/fridge"}, {"kolibrios/games/tyrian/", "../contrib/games/opentyrian/opentyrian"}, {"kolibrios/games/tyrian/data/", "common/games/tyrian/data/*"}, {"kolibrios/games/wolf3d/", "../contrib/games/wolf3d/wolf3d"}, {"kolibrios/games/wolf3d/", "common/games/wolf3d/*"}, {"kolibrios/develop/lua/lua", "../contrib/other/lua-5.2.0/lua"}, {"kolibrios/develop/lua/calc.lua", "../contrib/other/lua-5.2.0/calc.lua"}, {"kolibrios/develop/lua/console.lua", "../contrib/other/lua-5.2.0/console.lua"}, {"kolibrios/lib/libc.dll", "../contrib/sdk/bin/libc.dll", group = "../contrib/sdk/lib/"}, {"kolibrios/lib/sqlite3.dll", "../contrib/sdk/bin/sqlite3.dll", group = "../contrib/sdk/lib/"}, {"kolibrios/utils/minizip/minizip", PROGS .. "/fs/minizip/minizip"}, {"kolibrios/utils/minizip/miniunz", PROGS .. "/fs/minizip/miniunz"}, {"kolibrios/develop/c--/c--", PROGS .. "/develop/cmm/cmm"}, {"kolibrios/develop/tcc/tcc", PROGS .. "/develop/ktcc/trunk/source/tcc"}, {"kolibrios/develop/sqlite3/sqlite3", "../contrib/sdk/sources/sqlite3/shell/sqlite3"}, {"kolibrios/drivers/sensors/k10temp.sys", "../drivers/sensors/k10temp/k10temp.sys"}, }) -- For russian build, add russian-only programs. if build_type == "rus" then tup.append_table(extra_files, { {"kolibrios/games/21days", PROGS .. "/games/21days/21days"}, }) end end -- tup.getconfig('NO_GCC') ~= 'full' -- Skins. tup.include("../skins/skinlist.lua") --[================================[ CODE ]================================]-- -- expand extra_files and similar function expand_extra_files(files) local result = {} for i,v in ipairs(files) do if string.match(v[2], "%*") then local g = tup.glob(v[2]) for j,x in ipairs(g) do table.insert(result, {v[1], x, group=v.group}) end else if v.cp1251_from then tup.definerule{inputs = {v.cp1251_from}, command = 'iconv -f cp866 -t cp1251 "%f" > "%o"', outputs = {v[2]}} end table.insert(result, {v[1], v[2], group=v.group}) end end return result end -- append skins to extra_files for i,v in ipairs(skinlist) do table.insert(extra_files, {"kolibrios/res/skins/", "../skins/" .. v}) end -- prepare distr_extra_files and iso_extra_files: expand and append common part extra_files = expand_extra_files(extra_files) distr_extra_files = expand_extra_files(distr_extra_files) iso_extra_files = expand_extra_files(iso_extra_files) tup.append_table(distr_extra_files, extra_files) tup.append_table(iso_extra_files, extra_files) -- generate list of directories to be created inside kolibri.img img_dirs = {} input_deps = {} for i,v in ipairs(img_files) do img_file = v[1] local_file = v[2] slash_pos = 0 while true do slash_pos = string.find(img_file, '/', slash_pos + 1) if not slash_pos then break end table.insert(img_dirs, string.sub(img_file, 1, slash_pos - 1)) end -- tup does not want to see hidden files as dependencies if not string.match(local_file, "/%.") then table.insert(input_deps, v.group or local_file) end end -- create empty 1.44M file make_img_command = '^ MKIMG kolibri.img^ ' -- for tup: don't write full command to logs make_img_command = make_img_command .. "dd if=/dev/zero of=kolibri.img count=2880 bs=512 2>&1" -- format it as a standard 1.44M floppy make_img_command = make_img_command .. " && mformat -f 1440 -i kolibri.img ::" -- copy bootloader if tup.getconfig("NO_FASM") ~= "full" then bootloader = "../kernel/trunk/bootloader/boot_fat12.bin" make_img_command = make_img_command .. " && dd if=" .. bootloader .. " of=kolibri.img count=1 bs=512 conv=notrunc 2>&1" table.insert(input_deps, bootloader) end -- make folders table.sort(img_dirs) for i,v in ipairs(img_dirs) do if v ~= img_dirs[i-1] then make_img_command = make_img_command .. ' && mmd -i kolibri.img "::' .. v .. '"' end end -- copy files output_deps = {"kolibri.img"} for i,v in ipairs(img_files) do local_file = v[2] if v[1] == "KERNEL.MNT" and tup.getconfig("INSERT_REVISION_ID") ~= "" then -- for kernel.mnt, insert autobuild revision identifier -- from .revision to .kernel.mnt -- note that .revision and .kernel.mnt must begin with . -- to prevent tup from tracking them if build_type == "rus" then str='$(LANG=ru_RU.utf8 date -u +"[автосборка %d %b %Y %R, r$(get-current-revision)]"|iconv -f utf8 -t cp866)' else str='$(date -u +"[auto-build %d %b %Y %R, r$(get-current-revision)]")' end str = string.gsub(str, "%$", "\\$") -- escape $ as \$ str = string.gsub(str, "%%", "%%%%") -- escape % as %% make_img_command = make_img_command .. " && cp " .. local_file .. " .kernel.mnt" make_img_command = make_img_command .. " && str=" .. str make_img_command = make_img_command .. ' && echo -n $str | dd of=.kernel.mnt bs=1 seek=`expr 279 - length "$str"` conv=notrunc 2>/dev/null' local_file = ".kernel.mnt" table.insert(output_deps, local_file) end make_img_command = make_img_command .. ' && mcopy -moi kolibri.img "' .. local_file .. '" "::' .. v[1] .. '"' end -- generate tup rule for kolibri.img tup.definerule{inputs = input_deps, command = make_img_command, outputs = output_deps} -- generate command and dependencies for mkisofs input_deps = {"kolibri.img"} iso_files_list = "" for i,v in ipairs(iso_extra_files) do iso_files_list = iso_files_list .. ' "' .. v[1] .. '=' .. v[2] .. '"' table.insert(input_deps, v.group or v[2]) end -- generate tup rule for kolibri.iso if tup.getconfig("INSERT_REVISION_ID") ~= "" then volume_id = "KolibriOS r`get-current-revision`" else volume_id = "KolibriOS" end tup.definerule{inputs = input_deps, command = '^ MKISOFS kolibri.iso^ ' .. -- for tup: don't write full command to logs 'mkisofs -U -J -pad -b kolibri.img -c boot.catalog -hide-joliet boot.catalog -graft-points ' .. '-A "KolibriOS AutoBuilder" -p "CleverMouse" -publisher "KolibriOS Team" -V "' .. volume_id .. '" -sysid "KOLIBRI" ' .. '-iso-level 3 -o kolibri.iso kolibri.img' .. iso_files_list .. ' 2>&1', outputs = {"kolibri.iso"}} -- generate command and dependencies for distribution kit cp = 'cp "%f" "%o"' tup.definerule{inputs = {"kolibri.img"}, command = cp, outputs = {"distribution_kit/kolibri.img"}} for i,v in ipairs(distr_extra_files) do cmd = cp:gsub("%%f", v[2]) -- input can be a group, we can't rely on tup's expansion of %f in this case if string.sub(v[1], -1) == "/" then tup.definerule{inputs = {v.group or v[2]}, command = cmd, outputs = {"distribution_kit/" .. v[1] .. tup.file(v[2])}} else tup.definerule{inputs = {v.group or v[2]}, command = cmd, outputs = {"distribution_kit/" .. v[1]}} end end -- build kolibri.raw raw_mbr = "../programs/hd_load/usb_boot/mbr" raw_bootsector = "../kernel/trunk/bootloader/extended_primary_loader/fat32/bootsect.bin" raw_files = { {"KOLIBRI.IMG", "kolibri.img"}, {"KORDLDR.F32", "../kernel/trunk/bootloader/extended_primary_loader/fat32/kordldr.f32"}, {"KERNEL.MNT", "../kernel/trunk/kernel.mnt.ext_loader"}, {"CONFIG.INI", "../kernel/trunk/bootloader/extended_primary_loader/config.ini"}, {"EFI/BOOT/BOOTX64.EFI", "../kernel/trunk/bootloader/uefi4kos/bootx64.efi"}, {"EFI/BOOT/BOOTIA32.EFI", "../kernel/trunk/bootloader/uefi4kos/bootia32.efi"}, {"EFI/KOLIBRIOS/KOLIBRI.IMG", "kolibri.img"}, {"EFI/KOLIBRIOS/KOLIBRI.INI", "../kernel/trunk/bootloader/uefi4kos/kolibri.ini"}, {"EFI/KOLIBRIOS/KOLIBRI.KRN", "../kernel/trunk/kolibri.krn"} } for i,v in ipairs(img_files) do raw_file = "KOLIBRIOS/" .. string.upper(v[1]) local_file = v[2] tup.append_table(raw_files, {{raw_file, local_file}}) end tup.append_table(raw_files, extra_files) make_raw_command = '^ MKRAW kolibri.raw^ ' -- for tup: don't write full command to logs make_raw_command = make_raw_command .. "dd if=/dev/zero of=kolibri.raw bs=1MiB count=128 2>&1" make_raw_command = make_raw_command .. " && parted --script kolibri.raw mktable gpt" make_raw_command = make_raw_command .. " && parted --script kolibri.raw unit MiB mkpart primary fat32 1 127" make_raw_command = make_raw_command .. " && parted --script kolibri.raw set 1 esp on" make_raw_command = make_raw_command .. " && sgdisk kolibri.raw --hybrid 1:EE" make_raw_command = make_raw_command .. " && dd if=" .. raw_mbr .. " of=kolibri.raw bs=1 count=\\$((0x1b8)) conv=notrunc" make_raw_command = make_raw_command .. " && dd if=" .. raw_mbr .. " of=kolibri.raw bs=1 count=1 skip=\\$((0x5a)) seek=\\$((0x1be)) conv=notrunc" make_raw_command = make_raw_command .. " && mformat -i kolibri.raw@@1M -v KOLIBRIOS -T \\$(((128-1-1)*1024*1024/512)) -h 16 -s 32 -H 2048 -c 1 -F -B " .. raw_bootsector .. " ::" -- generate list of directories to be created inside kolibri.raw raw_dirs = {} input_deps = {raw_mbr, raw_bootsector} for i,v in ipairs(raw_files) do raw_file = v[1] local_file = v[2] cur_dir = "" for dir in string.gmatch(raw_file, "([^/]+)/") do cur_dir = cur_dir .. "/" .. string.upper(dir) raw_dirs[cur_dir] = true end -- tup does not want to see hidden files as dependencies if not string.match(local_file, "/%.") then table.insert(input_deps, v.group or local_file) end end -- Sorting is needed to mkdir /one before /one/two raw_dirs_sorted = {} for k in pairs(raw_dirs) do table.insert(raw_dirs_sorted, k) end table.sort(raw_dirs_sorted) raw_dirs = raw_dirs_sorted -- make folders table.sort(raw_dirs) for _, dir in pairs(raw_dirs) do make_raw_command = make_raw_command .. ' && mmd -i kolibri.raw@@1M "::' .. dir .. '"' end -- Put copying of raw_files into separate script to avoid 'execl: Argument list too long' make_raw_command2 = "true" -- copy files for i,v in ipairs(raw_files) do local_file = v[2] make_raw_command2 = make_raw_command2 .. ' && mcopy -moi kolibri.raw@@1M "' .. local_file .. '" "::' .. v[1] .. '"' end make_raw_command2_file = "make_raw_command2_file" tup.definerule{inputs = {}, command = "echo '" .. make_raw_command2 .. "' > " .. make_raw_command2_file, outputs = {make_raw_command2_file}} table.insert(input_deps, make_raw_command2_file) -- generate tup rule for kolibri.raw tup.definerule{inputs = input_deps, command = make_raw_command .. " && bash " .. make_raw_command2_file, outputs = {"kolibri.raw"}}