diff options
author | Alexander Kiryukhin <alexander@kiryukhin.su> | 2019-03-27 02:44:38 +0300 |
---|---|---|
committer | Alexander Kiryukhin <alexander@kiryukhin.su> | 2019-03-27 02:44:38 +0300 |
commit | d45d913c9e0d088f339c007f14d2fcaa7b9c8c74 (patch) | |
tree | 486d43d7359b5842f6f34b814764389fa27640d2 /options.go | |
parent | 11a32ca219905f7c42698b55b6af9920626b7b51 (diff) |
Flexible run policiesv0.3.0
Options refactoring
Diffstat (limited to 'options.go')
-rw-r--r--[-rwxr-xr-x] | options.go | 57 |
1 files changed, 9 insertions, 48 deletions
diff --git a/options.go b/options.go index 8144dde..d1030ba 100755..100644 --- a/options.go +++ b/options.go @@ -1,51 +1,12 @@ package rutina -import ( - "context" - "log" - "os" +type Options int + +const ( + ShutdownIfFail Options = iota // Shutdown all routines if fail + RestartIfFail // Restart this routine if fail + DoNothingIfFail // Do nothing on fail + ShutdownIfDone // Shutdown all routines if this routine done without errors + RestartIfDone // Restart if this routine done without errors + DoNothingIfDone // Do nothing if this routine done without errors ) - -type Option interface { - apply(*Rutina) -} - -type OptionContext struct { - Context context.Context -} - -func WithContext(context context.Context) *OptionContext { - return &OptionContext{Context: context} -} - -func (o OptionContext) apply(r *Rutina) { - ctx, cancel := context.WithCancel(o.Context) - r.ctx = ctx - r.Cancel = cancel -} - -type OptionLogger struct { - Logger *log.Logger -} - -func WithLogger(logger *log.Logger) *OptionLogger { - return &OptionLogger{Logger: logger} -} - -func WithStdLogger() *OptionLogger { - return &OptionLogger{Logger: log.New(os.Stdout, "rutina", log.LstdFlags)} -} - -func (o OptionLogger) apply(r *Rutina) { - r.logger = o.Logger -} - -type OptionCancelByError struct{} - -func WithCancelByError() *OptionCancelByError { - return &OptionCancelByError{} -} - -func (OptionCancelByError) apply(r *Rutina) { - r.cancelByError = true -} |