summaryrefslogtreecommitdiff
path: root/unix.go
blob: 7c9f8db8b5ee8a50aded79b2ed2eafd9157dd7f0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// This is a simple example
package main

import 	(
	"os"
	"os/exec"
	"strings"

	"go.wit.com/log"

//	"go.wit.com/gui/gui"
//	"go.wit.com/gui/gadgets"
//	"go.wit.com/apps/control-panel-dns/smartwindow"
)

func fullpath(repo string) string {
	return "/home/jcarr/go/src/" + repo
}

func run(path string, thing string, cmdline string) string {
	parts := strings.Split(cmdline, " ")
	// Create the command
	cmd := exec.Command(thing, parts...)

	// Set the working directory
	cmd.Dir = fullpath(path)

	// Execute the command
	output, err := cmd.CombinedOutput()
	if err != nil {
		log.Error(err, "cmd error'd out", parts)
		return ""
	}

	tmp := string(output)

	tmp = strings.TrimSpace(tmp)

	// Print the output
	log.Info("run()", path, thing, cmdline, "=", tmp)
	return tmp
}

func listFiles(directory string) []string {
	var files []string
	fileInfo, err := os.ReadDir(directory)
	if err != nil {
		log.Error(err)
		return nil
	}

	for _, file := range fileInfo {
		if !file.IsDir() {
			files = append(files, file.Name())
		}
	}

	return files
}

func runCmd(path string, cmdline string) (bool, string) {
	parts := strings.Split(cmdline, " ")
	if len(parts) == 0 {
		log.Warn("command line was empty")
		return false, ""
	}
	if parts[0] == "" {
		log.Warn("command line was empty")
		return false, ""
	}
	thing := parts[0]
	parts = parts[1:]

	log.Warn("path =", path, "thing =", thing, "cmdline =", parts)
	return false, ""
	// Create the command
	cmd := exec.Command(thing, parts...)

	// Set the working directory
	cmd.Dir = fullpath(path)

	// Execute the command
	output, err := cmd.CombinedOutput()
	if err != nil {
		log.Error(err)
		log.Warn("output was", output)
		log.Warn("cmd exited with error", err)
		return false, string(output)
	}

	tmp := string(output)
	tmp = strings.TrimSpace(tmp)

	// Print the output
	return true, tmp
}