diff options
| author | Furkan Sahin <furkan-dev@proton.me> | 2021-09-05 20:37:19 -0500 |
|---|---|---|
| committer | Furkan Sahin <furkan-dev@proton.me> | 2021-09-05 20:37:19 -0500 |
| commit | c36afa4b348a5450c59645b2be4e513a408fb54d (patch) | |
| tree | 790801a4ccd23190c6b08a02a6d92c4709ce6010 /runner_builder.go | |
| parent | 988becbc29376314b560927043669ba32deaf0d5 (diff) | |
| parent | 4b964d0d7b0d77d4cfcc6ddc1be1d3373cef82b2 (diff) | |
Merge branch 'upstream' into ppa
Merge v0.1.0
Diffstat (limited to 'runner_builder.go')
| -rw-r--r-- | runner_builder.go | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/runner_builder.go b/runner_builder.go new file mode 100644 index 0000000..b3c07d9 --- /dev/null +++ b/runner_builder.go @@ -0,0 +1,42 @@ +package planr + +type RunnerBuilder struct { + adapters map[string] Adapter + dirs DirConfig +} + +func ConfigureRunner() RunnerBuilder { + builder := RunnerBuilder{} + builder.adapters = make(map[string] Adapter, 0) + return builder +} + +func RegisterAdapter(b RunnerBuilder, a Adapter) RunnerBuilder { + nm := a.Config().Name + b.adapters[nm] = a + return b +} + +func SetConfigDirFromTree(b RunnerBuilder, childPath string) RunnerBuilder { + b.dirs.SetConfigFromTree(childPath) + return b +} + +func SetConfigDir(b RunnerBuilder, dir string) RunnerBuilder { + b.dirs.SetConfig(dir) + return b +} + +func SetBuildDir(b RunnerBuilder, dir string) RunnerBuilder { + b.dirs.SetBuild(dir) + return b +} + +func SetSrcDir(b RunnerBuilder, dir string) RunnerBuilder { + b.dirs.SetSrc(dir) + return b +} + +func (b RunnerBuilder) New() Runner { + return NewRunner(b.adapters, b.dirs) +} |
