|
|
|
@ -4,7 +4,6 @@ import ( |
|
|
|
"fmt" |
|
|
|
"fmt" |
|
|
|
"io" |
|
|
|
"io" |
|
|
|
"os" |
|
|
|
"os" |
|
|
|
"os/exec" |
|
|
|
|
|
|
|
"strings" |
|
|
|
"strings" |
|
|
|
"time" |
|
|
|
"time" |
|
|
|
|
|
|
|
|
|
|
|
@ -25,9 +24,7 @@ func SyncPackages(packages []string, logWriter io.Writer) error { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
args := append([]string{"-S", "--needed", "--noconfirm"}, packages...) |
|
|
|
args := append([]string{"-S", "--needed", "--noconfirm"}, packages...) |
|
|
|
cmdStr := "pacman " + strings.Join(args, " ") |
|
|
|
cmd := log.Command("pacman", args...) |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", cmdStr) |
|
|
|
|
|
|
|
cmd := exec.Command("pacman", args...) |
|
|
|
|
|
|
|
cmd.Stdout = logWriter |
|
|
|
cmd.Stdout = logWriter |
|
|
|
cmd.Stderr = logWriter |
|
|
|
cmd.Stderr = logWriter |
|
|
|
err := cmd.Run() |
|
|
|
err := cmd.Run() |
|
|
|
@ -47,8 +44,7 @@ func RefreshDB(logWriter io.Writer) error { |
|
|
|
logWriter = os.Stderr |
|
|
|
logWriter = os.Stderr |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fmt.Fprintf(logWriter, "[cmd] pacman -Syy\n") |
|
|
|
cmd := log.Command("pacman", "-Syy") |
|
|
|
cmd := exec.Command("pacman", "-Syy") |
|
|
|
|
|
|
|
cmd.Stdout = logWriter |
|
|
|
cmd.Stdout = logWriter |
|
|
|
cmd.Stderr = logWriter |
|
|
|
cmd.Stderr = logWriter |
|
|
|
if err := cmd.Run(); err != nil { |
|
|
|
if err := cmd.Run(); err != nil { |
|
|
|
@ -72,9 +68,7 @@ func MarkAs(packages []string, flag string, logWriter io.Writer) error { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
args := append([]string{"-D", "--" + flagName}, packages...) |
|
|
|
args := append([]string{"-D", "--" + flagName}, packages...) |
|
|
|
cmdStr := "pacman " + strings.Join(args, " ") |
|
|
|
cmd := log.Command("pacman", args...) |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", cmdStr) |
|
|
|
|
|
|
|
cmd := exec.Command("pacman", args...) |
|
|
|
|
|
|
|
cmd.Stdout = logWriter |
|
|
|
cmd.Stdout = logWriter |
|
|
|
cmd.Stderr = logWriter |
|
|
|
cmd.Stderr = logWriter |
|
|
|
err := cmd.Run() |
|
|
|
err := cmd.Run() |
|
|
|
@ -102,9 +96,7 @@ func RemoveOrphans(orphans []string, logWriter io.Writer) (int, error) { |
|
|
|
args := make([]string, 0, 3+len(orphans)) |
|
|
|
args := make([]string, 0, 3+len(orphans)) |
|
|
|
args = append(args, "pacman", "-Rns", "--noconfirm") |
|
|
|
args = append(args, "pacman", "-Rns", "--noconfirm") |
|
|
|
args = append(args, orphans...) |
|
|
|
args = append(args, orphans...) |
|
|
|
cmdStr := strings.Join(args, " ") |
|
|
|
removeCmd := log.Command(args[0], args[1:]...) |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", cmdStr) |
|
|
|
|
|
|
|
removeCmd := exec.Command(args[0], args[1:]...) |
|
|
|
|
|
|
|
removeCmd.Stdout = logWriter |
|
|
|
removeCmd.Stdout = logWriter |
|
|
|
removeCmd.Stderr = logWriter |
|
|
|
removeCmd.Stderr = logWriter |
|
|
|
err := removeCmd.Run() |
|
|
|
err := removeCmd.Run() |
|
|
|
@ -134,19 +126,15 @@ func InstallAUR(pkgName string, packageBase string, logWriter io.Writer) error { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
tmpDir := "/tmp/declpac-aur-" + pkgName |
|
|
|
tmpDir := "/tmp/declpac/" + pkgName |
|
|
|
mkdirCmdStr := "su - " + sudoUser + " -c 'rm -rf " + tmpDir + " && mkdir -p " + tmpDir + "'" |
|
|
|
mkdirCmd := log.Command("su", "-", sudoUser, "-c", "rm -rf "+tmpDir+" && mkdir -p "+tmpDir) |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", mkdirCmdStr) |
|
|
|
|
|
|
|
mkdirCmd := exec.Command("su", "-", sudoUser, "-c", "rm -rf "+tmpDir+" && mkdir -p "+tmpDir) |
|
|
|
|
|
|
|
if err := mkdirCmd.Run(); err != nil { |
|
|
|
if err := mkdirCmd.Run(); err != nil { |
|
|
|
return fmt.Errorf("failed to create temp directory: %w", err) |
|
|
|
return fmt.Errorf("failed to create temp directory: %w", err) |
|
|
|
} |
|
|
|
} |
|
|
|
defer os.RemoveAll(tmpDir) |
|
|
|
defer os.RemoveAll(tmpDir) |
|
|
|
|
|
|
|
|
|
|
|
cloneURL := "https://aur.archlinux.org/" + packageBase + ".git" |
|
|
|
cloneURL := "https://aur.archlinux.org/" + packageBase + ".git" |
|
|
|
cloneCmdStr := "su - " + sudoUser + " -c 'git clone " + cloneURL + " " + tmpDir + "'" |
|
|
|
cloneCmd := log.Command("su", "-", sudoUser, "-c", "git clone "+cloneURL+" "+tmpDir) |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", cloneCmdStr) |
|
|
|
|
|
|
|
cloneCmd := exec.Command("su", "-", sudoUser, "-c", "git clone "+cloneURL+" "+tmpDir) |
|
|
|
|
|
|
|
cloneCmd.Stdout = logWriter |
|
|
|
cloneCmd.Stdout = logWriter |
|
|
|
cloneCmd.Stderr = logWriter |
|
|
|
cloneCmd.Stderr = logWriter |
|
|
|
if err := cloneCmd.Run(); err != nil { |
|
|
|
if err := cloneCmd.Run(); err != nil { |
|
|
|
@ -154,9 +142,7 @@ func InstallAUR(pkgName string, packageBase string, logWriter io.Writer) error { |
|
|
|
} |
|
|
|
} |
|
|
|
log.Debug("InstallAUR: cloned (%.2fs)", time.Since(start).Seconds()) |
|
|
|
log.Debug("InstallAUR: cloned (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
makepkgCmdStr := "su - " + sudoUser + " -c 'cd " + tmpDir + " && makepkg -s --noconfirm'" |
|
|
|
makepkgCmd := log.Command("su", "-", sudoUser, "-c", "cd "+tmpDir+" && makepkg -s --noconfirm") |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", makepkgCmdStr) |
|
|
|
|
|
|
|
makepkgCmd := exec.Command("su", "-", sudoUser, "-c", "cd "+tmpDir+" && makepkg -s --noconfirm") |
|
|
|
|
|
|
|
makepkgCmd.Stdout = logWriter |
|
|
|
makepkgCmd.Stdout = logWriter |
|
|
|
makepkgCmd.Stderr = logWriter |
|
|
|
makepkgCmd.Stderr = logWriter |
|
|
|
if err := makepkgCmd.Run(); err != nil { |
|
|
|
if err := makepkgCmd.Run(); err != nil { |
|
|
|
@ -169,9 +155,7 @@ func InstallAUR(pkgName string, packageBase string, logWriter io.Writer) error { |
|
|
|
return fmt.Errorf("failed to find built package: %w", err) |
|
|
|
return fmt.Errorf("failed to find built package: %w", err) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
installCmdStr := "pacman -U --noconfirm " + pkgFile |
|
|
|
installCmd := log.Command("pacman", "-U", "--noconfirm", pkgFile) |
|
|
|
fmt.Fprintf(logWriter, "[cmd] %s\n", installCmdStr) |
|
|
|
|
|
|
|
installCmd := exec.Command("pacman", "-U", "--noconfirm", pkgFile) |
|
|
|
|
|
|
|
installCmd.Stdout = logWriter |
|
|
|
installCmd.Stdout = logWriter |
|
|
|
installCmd.Stderr = logWriter |
|
|
|
installCmd.Stderr = logWriter |
|
|
|
if err := installCmd.Run(); err != nil { |
|
|
|
if err := installCmd.Run(); err != nil { |
|
|
|
|