2019-01-12 04:58:27 +00:00
|
|
|
package dbus
|
|
|
|
|
|
|
|
import (
|
2019-12-12 01:27:03 +00:00
|
|
|
"context"
|
2019-01-12 04:58:27 +00:00
|
|
|
"errors"
|
|
|
|
)
|
|
|
|
|
2019-12-12 01:27:03 +00:00
|
|
|
var errSignature = errors.New("dbus: mismatched signature")
|
|
|
|
|
2019-01-12 04:58:27 +00:00
|
|
|
// Call represents a pending or completed method call.
|
|
|
|
type Call struct {
|
|
|
|
Destination string
|
|
|
|
Path ObjectPath
|
|
|
|
Method string
|
|
|
|
Args []interface{}
|
|
|
|
|
|
|
|
// Strobes when the call is complete.
|
|
|
|
Done chan *Call
|
|
|
|
|
|
|
|
// After completion, the error status. If this is non-nil, it may be an
|
|
|
|
// error message from the peer (with Error as its type) or some other error.
|
|
|
|
Err error
|
|
|
|
|
|
|
|
// Holds the response once the call is done.
|
|
|
|
Body []interface{}
|
2019-12-12 01:27:03 +00:00
|
|
|
|
|
|
|
// tracks context and canceler
|
|
|
|
ctx context.Context
|
|
|
|
ctxCanceler context.CancelFunc
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
2019-12-12 01:27:03 +00:00
|
|
|
func (c *Call) Context() context.Context {
|
|
|
|
if c.ctx == nil {
|
|
|
|
return context.Background()
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.ctx
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Call) ContextCancel() {
|
|
|
|
if c.ctxCanceler != nil {
|
|
|
|
c.ctxCanceler()
|
|
|
|
}
|
|
|
|
}
|
2019-01-12 04:58:27 +00:00
|
|
|
|
|
|
|
// Store stores the body of the reply into the provided pointers. It returns
|
|
|
|
// an error if the signatures of the body and retvalues don't match, or if
|
|
|
|
// the error status is not nil.
|
|
|
|
func (c *Call) Store(retvalues ...interface{}) error {
|
|
|
|
if c.Err != nil {
|
|
|
|
return c.Err
|
|
|
|
}
|
|
|
|
|
|
|
|
return Store(c.Body, retvalues...)
|
|
|
|
}
|
2019-12-12 01:27:03 +00:00
|
|
|
|
|
|
|
func (c *Call) done() {
|
|
|
|
c.Done <- c
|
|
|
|
c.ContextCancel()
|
|
|
|
}
|