3fde553297
This temp. expands the Exec method's signature but adds a more robust way to know when the container's process is actually released and begins to run. The network interfaces are not guaranteed to be up yet but this provides a more accurate view with a single callback at this time. Docker-DCO-1.1-Signed-off-by: Michael Crosby <michael@crosbymichael.com> (github: crosbymichael)
22 lines
704 B
Go
22 lines
704 B
Go
package nsinit
|
|
|
|
import "github.com/dotcloud/docker/pkg/libcontainer"
|
|
|
|
// NsInit is an interface with the public facing methods to provide high level
|
|
// exec operations on a container
|
|
type NsInit interface {
|
|
Exec(container *libcontainer.Container, term Terminal, pidRoot string, args []string, startCallback func()) (int, error)
|
|
ExecIn(container *libcontainer.Container, nspid int, args []string) (int, error)
|
|
Init(container *libcontainer.Container, uncleanRootfs, console string, syncPipe *SyncPipe, args []string) error
|
|
}
|
|
|
|
type linuxNs struct {
|
|
root string
|
|
commandFactory CommandFactory
|
|
}
|
|
|
|
func NewNsInit(command CommandFactory) NsInit {
|
|
return &linuxNs{
|
|
commandFactory: command,
|
|
}
|
|
}
|