homemaker/task.go

91 lines
2.4 KiB
Go
Raw Normal View History

2015-04-01 08:33:50 +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
2015-04-01 09:48:32 +00:00
import "fmt"
2015-04-01 08:33:50 +00:00
2015-07-20 04:55:24 +00:00
type taskDef struct {
Deps []string
Links []link
Cmds []command
Macros []macro
2015-04-01 08:33:50 +00:00
}
2015-07-20 04:55:24 +00:00
func (t *taskDef) process(taskName, srcDir, dstDir string, conf *config, flags int) error {
2015-04-09 10:29:25 +00:00
handled, ok := conf.tasksHandled[taskName]
if ok && handled {
return nil
}
conf.tasksHandled[taskName] = true
2015-06-17 13:20:01 +00:00
for _, depName := range t.Deps {
2015-04-02 09:16:59 +00:00
depTask, ok := conf.Tasks[depName]
2015-04-01 08:33:50 +00:00
if !ok {
2015-04-05 08:55:09 +00:00
return fmt.Errorf("task dependency not found %s", depName)
2015-04-01 08:33:50 +00:00
}
2015-04-09 10:29:25 +00:00
if err := depTask.process(depName, srcDir, dstDir, conf, flags); err != nil {
2015-04-01 09:44:10 +00:00
return err
}
}
2015-07-20 04:57:37 +00:00
if flags&flagNoMacro == 0 {
for _, macro := range t.Macros {
if len(macro) == 0 {
continue
}
2015-07-20 04:55:24 +00:00
2015-07-20 04:57:37 +00:00
macroName := macro[0]
macroParams := macro[1:]
2015-07-20 04:55:24 +00:00
2015-07-20 04:57:37 +00:00
depMacro, ok := conf.Macros[macroName]
if !ok {
return fmt.Errorf("macro dependency not found %s", macroName)
}
2015-07-20 04:55:24 +00:00
2015-07-20 04:57:37 +00:00
if err := depMacro.process(dstDir, macroParams, flags); err != nil {
return err
}
2015-07-20 04:55:24 +00:00
}
}
if flags&flagNoLink == 0 {
2015-06-17 13:20:01 +00:00
for _, currLink := range t.Links {
if err := currLink.process(srcDir, dstDir, flags); err != nil {
return err
}
2015-04-05 08:55:09 +00:00
}
}
if flags&flagNoCmd == 0 {
2015-06-17 13:20:01 +00:00
for _, currCmd := range t.Cmds {
if err := currCmd.process(dstDir, flags); err != nil {
return err
}
2015-04-01 08:33:50 +00:00
}
}
return nil
}