2015-04-12 20:34:20 +00:00
|
|
|
package wire
|
|
|
|
|
|
|
|
const (
|
|
|
|
// The official implementation of adb imposes an undocumented 255-byte limit
|
|
|
|
// on messages.
|
|
|
|
MaxMessageLength = 255
|
|
|
|
)
|
2015-04-11 21:45:29 +00:00
|
|
|
|
2015-04-12 20:34:20 +00:00
|
|
|
/*
|
|
|
|
Conn is a normal connection to an adb server.
|
2015-04-11 21:45:29 +00:00
|
|
|
|
|
|
|
For most cases, usage looks something like:
|
|
|
|
conn := wire.Dial()
|
|
|
|
conn.SendMessage(data)
|
2015-04-12 20:34:20 +00:00
|
|
|
conn.ReadStatus() == StatusSuccess || StatusFailure
|
2015-04-11 21:45:29 +00:00
|
|
|
conn.ReadMessage()
|
|
|
|
conn.Close()
|
|
|
|
|
|
|
|
For some messages, the server will return more than one message (but still a single
|
|
|
|
status). Generally, after calling ReadStatus once, you should call ReadMessage until
|
|
|
|
it returns an io.EOF error.
|
|
|
|
|
|
|
|
For most commands, the server will close the connection after sending the response.
|
|
|
|
You should still always call Close() when you're done with the connection.
|
|
|
|
*/
|
|
|
|
type Conn struct {
|
|
|
|
Scanner
|
|
|
|
Sender
|
2015-04-12 20:34:20 +00:00
|
|
|
closer func() error
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewConn(scanner Scanner, sender Sender, closer func() error) *Conn {
|
|
|
|
return &Conn{scanner, sender, closer}
|
2015-04-11 21:45:29 +00:00
|
|
|
}
|
|
|
|
|
2015-04-12 20:34:20 +00:00
|
|
|
// Close closes the underlying connection.
|
|
|
|
func (c *Conn) Close() error {
|
|
|
|
if c.closer != nil {
|
|
|
|
return c.closer()
|
|
|
|
}
|
|
|
|
return nil
|
2015-04-11 21:45:29 +00:00
|
|
|
}
|
|
|
|
|
2015-04-12 20:34:20 +00:00
|
|
|
// NewSyncConn returns connection that can operate in sync mode.
|
|
|
|
// The connection must already have been switched (by sending the sync command
|
|
|
|
// to a specific device), or the return connection will return an error.
|
|
|
|
func (c *Conn) NewSyncConn() *SyncConn {
|
|
|
|
return &SyncConn{
|
|
|
|
SyncScanner: c.Scanner.NewSyncScanner(),
|
|
|
|
SyncSender: c.Sender.NewSyncSender(),
|
|
|
|
}
|
2015-04-11 21:45:29 +00:00
|
|
|
}
|
|
|
|
|
2015-04-12 20:34:20 +00:00
|
|
|
// RoundTripSingleResponse sends a message to the server, and reads a single
|
|
|
|
// message response. If the reponse has a failure status code, returns it as an error.
|
|
|
|
func (conn *Conn) RoundTripSingleResponse(req []byte) (resp []byte, err error) {
|
|
|
|
if err = conn.SendMessage(req); err != nil {
|
2015-04-11 21:45:29 +00:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2015-04-12 20:34:20 +00:00
|
|
|
if err = ReadStatusFailureAsError(conn, req); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2015-04-11 21:45:29 +00:00
|
|
|
|
2015-04-12 20:34:20 +00:00
|
|
|
return conn.ReadMessage()
|
|
|
|
}
|