2013-01-18 19:13:39 -05:00
|
|
|
package docker
|
|
|
|
|
|
|
|
import (
|
2013-03-12 03:08:41 -04:00
|
|
|
"./future"
|
2013-03-12 08:36:37 -04:00
|
|
|
"fmt"
|
2013-01-28 17:30:05 -05:00
|
|
|
"sync"
|
|
|
|
"time"
|
2013-01-18 19:13:39 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
type State struct {
|
2013-01-22 20:30:37 -05:00
|
|
|
Running bool
|
|
|
|
Pid int
|
|
|
|
ExitCode int
|
2013-01-22 18:03:27 -05:00
|
|
|
StartedAt time.Time
|
2013-01-18 19:13:39 -05:00
|
|
|
|
|
|
|
stateChangeLock *sync.Mutex
|
|
|
|
stateChangeCond *sync.Cond
|
|
|
|
}
|
|
|
|
|
|
|
|
func newState() *State {
|
|
|
|
lock := new(sync.Mutex)
|
|
|
|
return &State{
|
|
|
|
stateChangeLock: lock,
|
|
|
|
stateChangeCond: sync.NewCond(lock),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-01-27 18:42:42 -05:00
|
|
|
// String returns a human-readable description of the state
|
|
|
|
func (s *State) String() string {
|
|
|
|
if s.Running {
|
2013-01-29 06:18:07 -05:00
|
|
|
return fmt.Sprintf("Up %s", future.HumanDuration(time.Now().Sub(s.StartedAt)))
|
2013-01-27 18:42:42 -05:00
|
|
|
}
|
2013-01-29 06:18:07 -05:00
|
|
|
return fmt.Sprintf("Exit %d", s.ExitCode)
|
2013-01-27 18:42:42 -05:00
|
|
|
}
|
|
|
|
|
2013-01-18 19:13:39 -05:00
|
|
|
func (s *State) setRunning(pid int) {
|
|
|
|
s.Running = true
|
|
|
|
s.ExitCode = 0
|
|
|
|
s.Pid = pid
|
2013-01-22 18:03:27 -05:00
|
|
|
s.StartedAt = time.Now()
|
2013-01-18 19:13:39 -05:00
|
|
|
s.broadcast()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *State) setStopped(exitCode int) {
|
|
|
|
s.Running = false
|
|
|
|
s.Pid = 0
|
|
|
|
s.ExitCode = exitCode
|
|
|
|
s.broadcast()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *State) broadcast() {
|
|
|
|
s.stateChangeLock.Lock()
|
|
|
|
s.stateChangeCond.Broadcast()
|
|
|
|
s.stateChangeLock.Unlock()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *State) wait() {
|
|
|
|
s.stateChangeLock.Lock()
|
|
|
|
s.stateChangeCond.Wait()
|
|
|
|
s.stateChangeLock.Unlock()
|
|
|
|
}
|