From 71bc5dadaa88c45e35f0d40ad071fa2bfd78850e Mon Sep 17 00:00:00 2001 From: rick Date: Mon, 14 Oct 2024 23:52:15 +0200 Subject: [PATCH] source: add mkisofs support (ticket #881) Signed-off-by: Rick G. --- distrobuilder/main_repack-windows.go | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/distrobuilder/main_repack-windows.go b/distrobuilder/main_repack-windows.go index 4a529e90..da95282b 100644 --- a/distrobuilder/main_repack-windows.go +++ b/distrobuilder/main_repack-windows.go @@ -304,13 +304,22 @@ func (c *cmdRepackWindows) run(cmd *cobra.Command, args []string, overlayDir str logger.Info("Generating new ISO") var stdout strings.Builder + var software string err = shared.RunCommand(c.global.ctx, nil, &stdout, "genisoimage", "--version") if err != nil { - return fmt.Errorf("Failed to determine version of genisoimage: %w", err) + err = shared.RunCommand(c.global.ctx, nil, &stdout, "mkisofs", "--version") + if err != nil { + return fmt.Errorf("Failed to determine version of genisoimage or mkisofs: %w", err) + } else { + software = "mkisofs" + } + } else { + software = "genisoimage" } version := strings.Split(stdout.String(), "\n")[0] + genArgs := []string{"-l", "-iso-level", "4", "-no-emul-boot", "-b", "boot/etfsboot.com", "-boot-load-seg", "0", "-boot-load-size", "8", "-eltorito-alt-boot"} @@ -337,7 +346,7 @@ func (c *cmdRepackWindows) run(cmd *cobra.Command, args []string, overlayDir str return os.Stderr.Write(b) })), - nil, nil, "genisoimage", genArgs...) + nil, nil, software, genArgs...) if err != nil { return fmt.Errorf("Failed to generate ISO: %w", err) @@ -426,7 +435,7 @@ func (c *cmdRepackWindows) modifyWimIndex(wimFile string, index int, name string } func (c *cmdRepackWindows) checkDependencies() error { - dependencies := []string{"genisoimage", "hivexregedit", "rsync", "wimlib-imagex"} + dependencies := []string{"hivexregedit", "rsync", "wimlib-imagex"} for _, dep := range dependencies { _, err := exec.LookPath(dep) @@ -435,6 +444,12 @@ func (c *cmdRepackWindows) checkDependencies() error { } } + _, err := exec.LookPath("genisoimage") + _, err1 := exec.LookPath("mkisofs") + if err != nil && err1 != nil { + return fmt.Errorf("Required tool genisoimage or mkisofs is missing") + } + return nil }