810 lines
28 KiB
Python
810 lines
28 KiB
Python
"""
|
|
* Author: "PeppermintOS Team(peppermintosteam@proton.me)
|
|
*
|
|
* License: SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
* Build the ISOs for the the system
|
|
"""
|
|
import os
|
|
from pathlib import Path
|
|
import argparse
|
|
import collections
|
|
import logging
|
|
import conf
|
|
import infra
|
|
import inflate_bubble
|
|
import finish_cleanup
|
|
|
|
# Set the home path used regardless the user logged in
|
|
BSTRING_ISO_CONFIGS = '~/bubbles/iso_configs'
|
|
HOME_FOLDER = str(Path(BSTRING_ISO_CONFIGS).expanduser())
|
|
FUSATO_ROOT = '/fusato'
|
|
WPCHROOT = '/fusato/config/includes.chroot'
|
|
|
|
|
|
# Set up the logging format
|
|
logger = logging.getLogger()
|
|
handler = logging.StreamHandler()
|
|
formatter = logging.Formatter(
|
|
'%(asctime)s %(name)-12s %(levelname)-8s %(message)s')
|
|
handler.setFormatter(formatter)
|
|
logger.addHandler(handler)
|
|
logger.setLevel(logging.DEBUG)
|
|
|
|
# Common Logging Messages
|
|
CFG_TREE_READY = "Config tree ready!"
|
|
CFG_READY = "Configs in place start the ISO build process"
|
|
START_LIVEBUILD = "Start Live-Build Process"
|
|
BUILD_COMPLETED = "ISO build has completed successfully"
|
|
BUILD_COMPLETED = "ISO is ready for usage."
|
|
|
|
|
|
class BuildXfce:
|
|
"""
|
|
Determine what base to use and then build the ISO
|
|
"""
|
|
def __init__(self, sbase, sarch):
|
|
self.sbase = sbase
|
|
self.sarch = sarch
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Determine what base to build
|
|
if sbase == "deb":
|
|
# Run the Debian Build
|
|
self.debian_build()
|
|
elif sbase == "dev":
|
|
self.devuan_build()
|
|
else:
|
|
print("No base has been found")
|
|
|
|
|
|
def debian_build(self):
|
|
"""
|
|
Used to build the Debian base XFCE ISO
|
|
"""
|
|
if self.sarch == '_64':
|
|
self.build_deb_64()
|
|
elif self.sarch == '_32':
|
|
self.build_deb_32()
|
|
elif self.sarch == '_arm':
|
|
self.build_deb_arm()
|
|
else:
|
|
logger.warning("No active build specified!")
|
|
|
|
def build_deb_64(self):
|
|
""" Builds the 64bit ISO XFCE"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
logger.info("Building a " + self.sbase + self.sarch[1:] + " bit ISO")
|
|
logger.info(dir_current)
|
|
bit_arch = self.sarch[1:]
|
|
# Start with the XFCE stuff
|
|
if bit_arch == 64:
|
|
cmd_list = collections.deque(conf.build64_xfce_build)
|
|
list_size = len(cmd_list)
|
|
for _ in range(list_size):
|
|
i = cmd_list.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
elif bit_arch == 32:
|
|
cmd_list = collections.deque(conf.build32_xfce_build)
|
|
list_size = len(cmd_list)
|
|
for _ in range(list_size):
|
|
i = cmd_list.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
elif bit_arch == "arm":
|
|
cmd_list = collections.deque(conf.buildarm_xfce_build)
|
|
list_size = len(cmd_list)
|
|
for _ in range(list_size):
|
|
i = cmd_list.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
else:
|
|
cmd_list = None
|
|
# Set the config tree
|
|
if bit_arch == 64:
|
|
lbsetup = conf.LBSET_DEB64
|
|
os.system(lbsetup)
|
|
elif bit_arch == 32:
|
|
lbsetup = conf.LBSET_DEB32
|
|
os.system(lbsetup)
|
|
elif bit_arch == "arm":
|
|
lbsetup = conf.LBSET_DEBARM
|
|
os.system(lbsetup)
|
|
else:
|
|
lbsetup = None
|
|
# Run the specific classes
|
|
infra.ChrootFolders(self.sbase, self.sarch)
|
|
infra.BinaryFolders(self.sbase, self.sarch)
|
|
infra.ArchitectureFiles(self.sbase, self.sarch)
|
|
infra.Archive(self.sbase, self.sarch)
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
logger.info(CFG_TREE_READY)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_xfce(self.sbase, self.sarch[1:])
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_debian_xfce_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_deb_32(self):
|
|
""" Builds the 32bit ISO XFCE"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
logger.info("Building a Debian based 32 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEB32
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the XFCE stuff
|
|
cmd_list_32 = collections.deque(conf.build32_xfce_build)
|
|
list_size_32 = len(cmd_list_32)
|
|
for _ in range(list_size_32):
|
|
i = cmd_list_32.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("deb", "_32")
|
|
infra.BinaryFolders("deb", "_32")
|
|
infra.ArchitectureFiles("deb", "_32")
|
|
infra.Archive("deb", "_32")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEB32
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_xfce("deb", "32")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_debian_xfce_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_deb_arm(self):
|
|
""" Builds the arm ISO XFCE"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
logger.info("Building a Debian based arm bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEBARM
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the XFCE stuff
|
|
cmd_list_arm = collections.deque(conf.buildarm_xfce_build)
|
|
list_size_arm = len(cmd_list_arm)
|
|
for _ in range(list_size_arm):
|
|
i = cmd_list_arm.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("deb", "_arm")
|
|
infra.BinaryFolders("deb", "_arm")
|
|
infra.ArchitectureFiles("deb", "_arm")
|
|
infra.Archive("deb", "_arm")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEBARM
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_xfce("deb", "arm")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_debian_xfce_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
|
|
|
|
|
|
def build_dev_64(self):
|
|
""" Builds the 64bit ISO XFCE"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
logger.info("Building a devuan based 64 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEV64
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the XFCE stuff
|
|
cmd_list_64 = collections.deque(conf.build64_xfce_build)
|
|
list_size_64 = len(cmd_list_64)
|
|
for _ in range(list_size_64):
|
|
i = cmd_list_64.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("dev", "_64")
|
|
infra.BinaryFolders("dev", "_64")
|
|
infra.ArchitectureFiles("dev", "_64")
|
|
infra.Archive("dev", "_64")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEV64
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_xfce("dev","64")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_devuan_xfce_based()
|
|
finish_cleanup.kill_old_iso()
|
|
#'finish_cleanup.copy_iso_file_prod_deb64',
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_dev_32(self):
|
|
""" Builds the 32bit ISO XFCE"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
logger.info("Building a devuan based 32 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEV32
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the XFCE stuff
|
|
cmd_list_32 = collections.deque(conf.build32_xfce_build)
|
|
list_size_32 = len(cmd_list_32)
|
|
for _ in range(list_size_32):
|
|
i = cmd_list_32.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("dev", "_32")
|
|
infra.BinaryFolders("dev", "_32")
|
|
infra.ArchitectureFiles("dev", "_32")
|
|
infra.Archive("dev", "_32")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEV32
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_xfce("dev","32")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_devuan_xfce_based()
|
|
finish_cleanup.kill_old_iso()
|
|
#'finish_cleanup.copy_iso_file_prod_deb32',
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_dev_arm(self):
|
|
""" Builds the arm ISO XFCE"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
print("INFO: Building a devuan based arm bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEVARM
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the XFCE stuff
|
|
cmd_list_arm = collections.deque(conf.buildarm_xfce_build)
|
|
list_size_arm = len(cmd_list_arm)
|
|
for _ in range(list_size_arm):
|
|
i = cmd_list_arm.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("dev", "_arm")
|
|
infra.BinaryFolders("dev", "_arm")
|
|
infra.ArchitectureFiles("dev", "_arm")
|
|
infra.Archive("dev", "_arm")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEVARM
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_xfce("dev","arm")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_devuan_xfce_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def devuan_build(self):
|
|
"""
|
|
Used to build the devuan base XFCE ISO
|
|
"""
|
|
if self.sarch == '_64':
|
|
self.build_dev_64()
|
|
elif self.sarch == '_32':
|
|
self.build_dev_32()
|
|
elif self.sarch == '_arm':
|
|
self.build_dev_arm()
|
|
else:
|
|
print("WARNING: No active build specified")
|
|
|
|
|
|
class BuildGflashback:
|
|
"""
|
|
Determine what base to use and then build the ISO
|
|
"""
|
|
def __init__(self, sbase, sarch):
|
|
self.sbase = sbase
|
|
self.sarch = sarch
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Determine what base to build
|
|
if sbase == "deb":
|
|
# Run the Debian Build
|
|
self.debian_build()
|
|
elif sbase == "dev":
|
|
self.devuan_build()
|
|
else:
|
|
print("No base has been found")
|
|
|
|
|
|
def build_deb_64(self):
|
|
""" Builds the 64bit ISO GNOME FlashBack"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
logger.info("Building a Debian based 64 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEB64
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the GNOME FlashBack stuff
|
|
cmd_list_64 = collections.deque(conf.build64_gfb_build)
|
|
list_size_64 = len(cmd_list_64)
|
|
for _ in range(list_size_64):
|
|
i = cmd_list_64.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("deb", "_64")
|
|
infra.BinaryFolders("deb", "_64")
|
|
infra.ArchitectureFiles("deb", "_64")
|
|
infra.Archive("deb", "_64")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEB64
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_gnomeflashback("deb","64")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_debian_gfb_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_deb_32(self):
|
|
""" Builds the 32bit ISO GNOME FlashBack"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
print("INFO: Building a Debian based 32 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEB32
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the GNOME FlashBack stuff
|
|
cmd_list_32 = collections.deque(conf.build32_gfb_build)
|
|
list_size_32 = len(cmd_list_32)
|
|
for _ in range(list_size_32):
|
|
i = cmd_list_32.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("deb", "_32")
|
|
infra.BinaryFolders("deb", "_32")
|
|
infra.ArchitectureFiles("deb", "_32")
|
|
infra.Archive("deb", "_32")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEB32
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_gnomeflashback("deb","32")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_debian_gfb_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_deb_arm(self):
|
|
""" Builds the arm ISO GNOME FlashBack"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
print("INFO: Building a Debian based arm bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEBARM
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the GNOME FlashBack stuff
|
|
cmd_list_arm = collections.deque(conf.buildarm_gfb_build)
|
|
list_size_arm = len(cmd_list_arm)
|
|
for _ in range(list_size_arm):
|
|
i = cmd_list_arm.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("deb", "_arm")
|
|
infra.BinaryFolders("deb", "_arm")
|
|
infra.ArchitectureFiles("deb", "_arm")
|
|
infra.Archive("deb", "_arm")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEBARM
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_gnomeflashback("deb","arm")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_debian_gfb_based()
|
|
finish_cleanup.kill_old_iso()
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def debian_build(self):
|
|
"""
|
|
Used to build the Debian base GNOME FlashBack ISO
|
|
"""
|
|
if self.sarch == '_64':
|
|
self.build_deb_64()
|
|
elif self.sarch == '_32':
|
|
self.build_deb_32()
|
|
elif self.sarch == '_arm':
|
|
self.build_deb_arm()
|
|
else:
|
|
print("WARNING: No active build specified")
|
|
|
|
|
|
def build_dev_64(self):
|
|
""" Builds the 64bit ISO GNOME FlashBack"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
print("INFO: Building a devuan based 64 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEV64
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the GNOME FlashBack stuff
|
|
cmd_list_64 = collections.deque(conf.build64_gfb_build)
|
|
list_size_64 = len(cmd_list_64)
|
|
for _ in range(list_size_64):
|
|
i = cmd_list_64.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("dev", "_64")
|
|
infra.BinaryFolders("dev", "_64")
|
|
infra.ArchitectureFiles("dev", "_64")
|
|
infra.Archive("dev", "_64")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEV64
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_gnomeflashback("dev","64")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_devuan_gfb_based()
|
|
finish_cleanup.kill_old_iso()
|
|
#'finish_cleanup.copy_iso_file_prod_deb64',
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_dev_32(self):
|
|
""" Builds the 32bit ISO GNOME FlashBack"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
print("INFO: Building a devuan based 32 bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEV32
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the GNOME FlashBack stuff
|
|
cmd_list_32 = collections.deque(conf.build32_gfb_build)
|
|
list_size_32 = len(cmd_list_32)
|
|
for _ in range(list_size_32):
|
|
i = cmd_list_32.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("dev", "_32")
|
|
infra.BinaryFolders("dev", "_32")
|
|
infra.ArchitectureFiles("dev", "_32")
|
|
infra.Archive("dev", "_32")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEV32
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_gnomeflashback("dev","32")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_devuan_gfb_based()
|
|
finish_cleanup.kill_old_iso()
|
|
#'finish_cleanup.copy_iso_file_prod_deb32',
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def build_dev_arm(self):
|
|
""" Builds the arm ISO GNOME FlashBack"""
|
|
current_working_directory = os.getcwd()
|
|
dir_current = "Current working directory" + current_working_directory
|
|
print("INFO: Building a devuan based arm bit ISO")
|
|
logger.info(dir_current)
|
|
# Set the config tree
|
|
lbsetup = conf.LBSET_DEVARM
|
|
os.system(lbsetup)
|
|
logger.info(CFG_TREE_READY)
|
|
# Start with the GNOME FlashBack stuff
|
|
cmd_list_arm = collections.deque(conf.buildarm_gfb_build)
|
|
list_size_arm = len(cmd_list_arm)
|
|
for _ in range(list_size_arm):
|
|
i = cmd_list_arm.popleft()
|
|
execute = i + '()'
|
|
exec(execute)
|
|
# Run the specific classes
|
|
infra.ChrootFolders("dev", "_arm")
|
|
infra.BinaryFolders("dev", "_arm")
|
|
infra.ArchitectureFiles("dev", "_arm")
|
|
infra.Archive("dev", "_arm")
|
|
# Run the Build
|
|
logger.info(CFG_READY)
|
|
logger.info(START_LIVEBUILD)
|
|
logger.info(dir_current)
|
|
lbsetup = conf.LBSET_DEVARM
|
|
os.system(lbsetup)
|
|
run_cmd = 'sudo lb build'
|
|
current_working_directory = os.getcwd()
|
|
os.chdir(HOME_FOLDER + FUSATO_ROOT)
|
|
# Set the build inidcator
|
|
inflate_bubble.make_bld_gnomeflashback("dev", "arm")
|
|
logger.info(dir_current)
|
|
os.system(run_cmd)
|
|
logger.info(BUILD_COMPLETED)
|
|
logger.info(dir_current)
|
|
finish_cleanup.make_check_sum()
|
|
finish_cleanup.copy_devuan_gfb_based()
|
|
finish_cleanup.kill_old_iso()
|
|
#'finish_cleanup.copy_iso_file_prod_DEBARM',
|
|
logger.info(BUILD_COMPLETED)
|
|
|
|
|
|
def devuan_build(self):
|
|
"""
|
|
Used to build the devuan base GNOME FlashBack ISO
|
|
"""
|
|
if self.sarch == '_64':
|
|
self.build_dev_64()
|
|
elif self.sarch == '_32':
|
|
self.build_dev_32()
|
|
elif self.sarch == '_arm':
|
|
self.build_dev_arm()
|
|
else:
|
|
print("WARNING: No active build specified")
|
|
|
|
|
|
def readybuild():
|
|
"""" Make Ready the bld structure If fusato exists remove it.
|
|
and recreate it, otherwise just make a new folder named
|
|
fusato.
|
|
"""
|
|
logger.info("Making ready the fusato build directory")
|
|
os.chdir(HOME_FOLDER)
|
|
if os.path.exists('fusato'):
|
|
rm_cmd = "sudo rm -r -f fusato"
|
|
os.system(rm_cmd)
|
|
os.makedirs('fusato')
|
|
else:
|
|
os.makedirs('fusato')
|
|
|
|
|
|
class Decsions:
|
|
"""
|
|
Aguments used to tell the application what to build
|
|
"""
|
|
def __init__(self):
|
|
# Set up the terminal arguments
|
|
self.argument_parser = argparse.ArgumentParser()
|
|
self.argument_parser.add_argument("set",
|
|
help="set what build to start",
|
|
type=str
|
|
)
|
|
self.argument_parser.add_argument("e",
|
|
help="identify the desktop"
|
|
" environment for example"
|
|
" e-xfce",
|
|
type=str
|
|
)
|
|
self.argument_parser.add_argument("b",
|
|
help="identify the ISO to"
|
|
"build for example"
|
|
" b-deb64",
|
|
type=str
|
|
)
|
|
self.arguments = self.argument_parser.parse_args()
|
|
# Then determine what desktop build to look for
|
|
if self.arguments.e == 'e-gnomefb':
|
|
self.dgnomefb()
|
|
elif self.arguments.e == 'e-xfce':
|
|
self.dxfce()
|
|
elif self.arguments.e == 'e-openbox':
|
|
self.dopenbox()
|
|
|
|
|
|
def dxfce(self):
|
|
""" Arguments for the XFCE """
|
|
if self.arguments.e == 'e-xfce':
|
|
if self.arguments.b == 'b-deb64':
|
|
readybuild()
|
|
BuildXfce("deb", "_64")
|
|
elif self.arguments.b == 'b-deb32':
|
|
readybuild()
|
|
BuildXfce("deb", "_32")
|
|
elif self.arguments.b == 'b-dev64':
|
|
readybuild()
|
|
BuildXfce("dev", "_64")
|
|
elif self.arguments.b == 'b-dev32':
|
|
readybuild()
|
|
BuildXfce("dev", "_32")
|
|
elif self.arguments.b == 'b-debarm':
|
|
readybuild()
|
|
BuildXfce("deb", "_arm")
|
|
elif self.arguments.b == 'b-devarm':
|
|
readybuild()
|
|
BuildXfce("dev", "_arm")
|
|
else:
|
|
logger.critical("You have not specified a build to process!")
|
|
|
|
|
|
def dgnomefb(self):
|
|
""" Arguments for the gnomefb """
|
|
if self.arguments.e == 'e-gnomefb':
|
|
if self.arguments.b == 'b-deb64':
|
|
readybuild()
|
|
BuildGflashback("deb", "_64")
|
|
elif self.arguments.b == 'b-deb32':
|
|
readybuild()
|
|
BuildGflashback("deb", "_32")
|
|
elif self.arguments.b == 'b-debarm':
|
|
readybuild()
|
|
BuildGflashback("deb", "_arm")
|
|
elif self.arguments.b == 'b-dev32':
|
|
readybuild()
|
|
BuildGflashback("dev", "_32")
|
|
elif self.arguments.b == 'b-dev64':
|
|
readybuild()
|
|
BuildGflashback("dev", "_64")
|
|
elif self.arguments.b == 'b-devarm':
|
|
readybuild()
|
|
BuildGflashback("dev", "_arm")
|
|
else:
|
|
logger.critical("You have not specified a build to process!")
|
|
|
|
|
|
def dopenbox(self):
|
|
""" Arguments for the openbox """
|
|
if self.arguments.e == 'e-openbox':
|
|
if self.arguments.b == 'b-deb64':
|
|
readybuild()
|
|
print('run openbox builds deb64')
|
|
elif self.arguments.b == 'b-deb32':
|
|
readybuild()
|
|
print('run openbox builds deb32')
|
|
elif self.arguments.b == 'b-dev64':
|
|
readybuild()
|
|
print('run openbox builds dev64')
|
|
elif self.arguments.b == 'b-dev32':
|
|
readybuild()
|
|
print('run openbox builds dev32')
|
|
elif self.arguments.b == 'b-debarm':
|
|
readybuild()
|
|
print('run openbox builds debarm')
|
|
elif self.arguments.b == 'b-devarm':
|
|
readybuild()
|
|
print('run openbox builds devarm')
|
|
else:
|
|
print('You have not specified a valid '
|
|
'build architecture!!')
|
|
else:
|
|
logger.critical("You have not specified a valid "
|
|
"desktop environment!!")
|
|
|
|
|
|
Decsions()
|