Skip to content

Commit

Permalink
Support -a command line arguments
Browse files Browse the repository at this point in the history
For supporting and commandline arugment to pass to the binary
there is a new '-a' option. Also my editor autoformats to
gofmt so these files are cleaned up with the standarde format.
  • Loading branch information
lateefj committed May 7, 2014
1 parent 150192b commit 9aecf40
Show file tree
Hide file tree
Showing 3 changed files with 146 additions and 132 deletions.
34 changes: 17 additions & 17 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,24 +13,24 @@ Traffic (https://github.com/pilu/traffic) already has a middleware that shows th
package main

import (
"flag"
"fmt"
"github.com/pilu/fresh/runner"
"os"
"flag"
"fmt"
"github.com/lateefj/fresh/runner"
"os"
)

func main() {
configPath := flag.String("c", "", "config file path")
flag.Parse()

if *configPath != "" {
if _, err := os.Stat(*configPath); err != nil {
fmt.Printf("Can't find config file `%s`\n", *configPath)
os.Exit(1)
} else {
os.Setenv("RUNNER_CONFIG_PATH", *configPath)
}
}

runner.Start()
configPath := flag.String("c", "", "config file path")
flag.Parse()

if *configPath != "" {
if _, err := os.Stat(*configPath); err != nil {
fmt.Printf("Can't find config file `%s`\n", *configPath)
os.Exit(1)
} else {
os.Setenv("RUNNER_CONFIG_PATH", *configPath)
}
}

runner.Start()
}
76 changes: 45 additions & 31 deletions runner/runner.go
Original file line number Diff line number Diff line change
@@ -1,39 +1,53 @@
package runner

import (
"io"
"os/exec"
"flag"
"io"
"os/exec"
"strings"
)

func run() bool {
runnerLog("Running...")

cmd := exec.Command(buildPath())

stderr, err := cmd.StderrPipe()
if err != nil {
fatal(err)
}

stdout, err := cmd.StdoutPipe()
if err != nil {
fatal(err)
}
var cmdArgs string

err = cmd.Start()
if err != nil {
fatal(err)
}

go io.Copy(appLogWriter{}, stderr)
go io.Copy(appLogWriter{}, stdout)

go func() {
<-stopChannel
pid := cmd.Process.Pid
runnerLog("Killing PID %d", pid)
cmd.Process.Kill()
}()
func init() {
flag.StringVar(&cmdArgs, "a", "", "Command line arguments to pass to the process")
}

return true
func run() bool {
runnerLog("Running...")

var cmd *exec.Cmd
if cmdArgs != "" {
args := strings.Split(cmdArgs, " ")
cmd = exec.Command(buildPath(), args...)
} else {
cmd = exec.Command(buildPath())
}

stderr, err := cmd.StderrPipe()
if err != nil {
fatal(err)
}

stdout, err := cmd.StdoutPipe()
if err != nil {
fatal(err)
}

err = cmd.Start()
if err != nil {
fatal(err)
}

go io.Copy(appLogWriter{}, stderr)
go io.Copy(appLogWriter{}, stdout)

go func() {
<-stopChannel
pid := cmd.Process.Pid
runnerLog("Killing PID %d", pid)
cmd.Process.Kill()
}()

return true
}
168 changes: 84 additions & 84 deletions runner/settings.go
Original file line number Diff line number Diff line change
@@ -1,138 +1,138 @@
package runner

import (
"fmt"
"github.com/pilu/config"
"os"
"path/filepath"
"strconv"
"strings"
"time"
"fmt"
"github.com/pilu/config"
"os"
"path/filepath"
"strconv"
"strings"
"time"
)

const (
envSettingsPrefix = "RUNNER_"
mainSettingsSection = "Settings"
envSettingsPrefix = "RUNNER_"
mainSettingsSection = "Settings"
)

var settings = map[string]string{
"config_path": "./runner.conf",
"root": ".",
"tmp_path": "./tmp",
"build_name": "runner-build",
"build_log": "runner-build-errors.log",
"valid_ext": ".go, .tpl, .tmpl, .html",
"build_delay": "600",
"colors": "1",
"log_color_main": "cyan",
"log_color_build": "yellow",
"log_color_runner": "green",
"log_color_watcher": "magenta",
"log_color_app": "",
"config_path": "./runner.conf",
"root": ".",
"tmp_path": "./tmp",
"build_name": "runner-build",
"build_log": "runner-build-errors.log",
"valid_ext": ".go, .tpl, .tmpl, .html",
"build_delay": "600",
"colors": "1",
"log_color_main": "cyan",
"log_color_build": "yellow",
"log_color_runner": "green",
"log_color_watcher": "magenta",
"log_color_app": "",
}

var colors = map[string]string{
"reset": "0",
"black": "30",
"red": "31",
"green": "32",
"yellow": "33",
"blue": "34",
"magenta": "35",
"cyan": "36",
"white": "37",
"bold_black": "30;1",
"bold_red": "31;1",
"bold_green": "32;1",
"bold_yellow": "33;1",
"bold_blue": "34;1",
"bold_magenta": "35;1",
"bold_cyan": "36;1",
"bold_white": "37;1",
"bright_black": "30;2",
"bright_red": "31;2",
"bright_green": "32;2",
"bright_yellow": "33;2",
"bright_blue": "34;2",
"bright_magenta": "35;2",
"bright_cyan": "36;2",
"bright_white": "37;2",
"reset": "0",
"black": "30",
"red": "31",
"green": "32",
"yellow": "33",
"blue": "34",
"magenta": "35",
"cyan": "36",
"white": "37",
"bold_black": "30;1",
"bold_red": "31;1",
"bold_green": "32;1",
"bold_yellow": "33;1",
"bold_blue": "34;1",
"bold_magenta": "35;1",
"bold_cyan": "36;1",
"bold_white": "37;1",
"bright_black": "30;2",
"bright_red": "31;2",
"bright_green": "32;2",
"bright_yellow": "33;2",
"bright_blue": "34;2",
"bright_magenta": "35;2",
"bright_cyan": "36;2",
"bright_white": "37;2",
}

func logColor(logName string) string {
settingsKey := fmt.Sprintf("log_color_%s", logName)
colorName := settings[settingsKey]
settingsKey := fmt.Sprintf("log_color_%s", logName)
colorName := settings[settingsKey]

return colors[colorName]
return colors[colorName]
}

func loadEnvSettings() {
for key, _ := range settings {
envKey := fmt.Sprintf("%s%s", envSettingsPrefix, strings.ToUpper(key))
if value := os.Getenv(envKey); value != "" {
settings[key] = value
}
}
for key, _ := range settings {
envKey := fmt.Sprintf("%s%s", envSettingsPrefix, strings.ToUpper(key))
if value := os.Getenv(envKey); value != "" {
settings[key] = value
}
}
}

func loadRunnerConfigSettings() {
if _, err := os.Stat(configPath()); err != nil {
return
}

logger.Printf("Loading settings from %s", configPath())
sections, err := config.ParseFile(configPath(), mainSettingsSection)
if err != nil {
return
}

for key, value := range sections[mainSettingsSection] {
settings[key] = value
}
if _, err := os.Stat(configPath()); err != nil {
return
}

logger.Printf("Loading settings from %s", configPath())
sections, err := config.ParseFile(configPath(), mainSettingsSection)
if err != nil {
return
}

for key, value := range sections[mainSettingsSection] {
settings[key] = value
}
}

func initSettings() {
loadEnvSettings()
loadRunnerConfigSettings()
loadEnvSettings()
loadRunnerConfigSettings()
}

func getenv(key, defaultValue string) string {
if value := os.Getenv(key); value != "" {
return value
}
if value := os.Getenv(key); value != "" {
return value
}

return defaultValue
return defaultValue
}

func root() string {
return settings["root"]
return settings["root"]
}

func tmpPath() string {
return settings["tmp_path"]
return settings["tmp_path"]
}

func buildName() string {
return settings["build_name"]
return settings["build_name"]
}
func buildPath() string {
return filepath.Join(tmpPath(), buildName())
return filepath.Join(tmpPath(), buildName())
}

func buildErrorsFileName() string {
return settings["build_log"]
return settings["build_log"]
}

func buildErrorsFilePath() string {
return filepath.Join(tmpPath(), buildErrorsFileName())
return filepath.Join(tmpPath(), buildErrorsFileName())
}

func configPath() string {
return settings["config_path"]
return settings["config_path"]
}

func buildDelay() time.Duration {
value, _ := strconv.Atoi(settings["build_delay"])
value, _ := strconv.Atoi(settings["build_delay"])

return time.Duration(value)
return time.Duration(value)
}

0 comments on commit 9aecf40

Please sign in to comment.