homemaker/command.go

83 lines
2.3 KiB
Go
Raw Normal View History

2015-04-05 08:55:09 +00:00
/*
* Copyright (c) 2015 Alex Yatskov <alex@foosoft.net>
* Author: Alex Yatskov <alex@foosoft.net>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal in
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
* the Software, and to permit persons to whom the Software is furnished to do so,
* subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package main
import (
"fmt"
"log"
"os"
"os/exec"
"strings"
)
2015-07-20 10:42:08 +00:00
type macro struct {
Prefix []string
Suffix []string
}
2015-07-20 10:42:08 +00:00
func processCmd(params []string, dir string, conf *config, flags int) error {
args := appendExpEnv(nil, params)
if len(args) == 0 {
2015-07-20 11:29:05 +00:00
return fmt.Errorf("invalid command statement")
2015-04-05 08:55:09 +00:00
}
2015-07-20 10:42:08 +00:00
cmdName := args[0]
if strings.HasPrefix(cmdName, "@") {
macroName := strings.TrimPrefix(cmdName, "@")
m, ok := conf.Macros[macroName]
if !ok {
2015-07-20 11:03:26 +00:00
return fmt.Errorf("macro not found %s", macroName)
2015-07-20 10:42:08 +00:00
}
2015-07-20 11:29:05 +00:00
margs := appendExpEnv(nil, m.Prefix)
2015-07-20 10:42:08 +00:00
if len(args) > 1 {
2015-07-20 11:29:05 +00:00
margs = appendExpEnv(margs, args[1:])
2015-07-20 10:42:08 +00:00
}
2015-07-20 11:29:05 +00:00
margs = appendExpEnv(margs, m.Suffix)
2015-07-20 11:03:26 +00:00
2015-08-10 04:42:31 +00:00
if flags&FLAG_VERBOSE == FLAG_VERBOSE {
2015-07-20 11:03:26 +00:00
log.Printf("using macro %s", macroName)
}
2015-07-20 11:29:05 +00:00
return processCmd(margs, dir, conf, flags)
}
var cmdArgs []string
if len(args) > 1 {
2015-07-20 10:42:08 +00:00
cmdArgs = args[1:]
}
cmd := exec.Command(cmdName, cmdArgs...)
2015-04-05 08:55:09 +00:00
cmd.Dir = dir
cmd.Stderr = os.Stderr
cmd.Stdout = os.Stdout
2015-06-23 06:14:06 +00:00
cmd.Stdin = os.Stdin
2015-04-05 08:55:09 +00:00
2015-08-10 04:42:31 +00:00
if flags&FLAG_VERBOSE == FLAG_VERBOSE {
2015-07-20 10:42:08 +00:00
log.Printf("executing command %s %s", cmdName, strings.Join(cmdArgs, " "))
2015-04-05 08:55:09 +00:00
}
return cmd.Run()
}