Move files from gousb/usb to gousb
This commit is contained in:
@@ -23,4 +23,4 @@ script:
|
|||||||
- |-
|
- |-
|
||||||
echo 'mode: count' > coverage.merged && go list ./... | xargs -n1 -I{} sh -c ': > coverage.tmp; go test -v -covermode=count -coverprofile=coverage.tmp {} && tail -n +2 coverage.tmp >> coverage.merged' && rm coverage.tmp
|
echo 'mode: count' > coverage.merged && go list ./... | xargs -n1 -I{} sh -c ': > coverage.tmp; go test -v -covermode=count -coverprofile=coverage.tmp {} && tail -n +2 coverage.tmp >> coverage.merged' && rm coverage.tmp
|
||||||
- |-
|
- |-
|
||||||
$HOME/gopath/bin/goveralls -coverprofile=coverage.merged -service=travis-ci -ignore usb/libusb.go,usb/error.go || true
|
$HOME/gopath/bin/goveralls -coverprofile=coverage.merged -service=travis-ci -ignore libusb.go,error.go || true
|
||||||
|
|||||||
@@ -53,11 +53,11 @@ If you installed the lsusb example, both libraries below are already installed.
|
|||||||
|
|
||||||
Installing the primary gousb package is really easy:
|
Installing the primary gousb package is really easy:
|
||||||
|
|
||||||
go get -v github.com/google/gousb/usb
|
go get -v github.com/google/gousb
|
||||||
|
|
||||||
There is also a `usbid` package that will not be installed by default by this command, but which provides useful information including the human-readable vendor and product codes for detected hardware. It's not installed by default and not linked into the `usb` package by default because it adds ~400kb to the resulting binary. If you want both, they can be installed thus:
|
There is also a `usbid` package that will not be installed by default by this command, but which provides useful information including the human-readable vendor and product codes for detected hardware. It's not installed by default and not linked into the `gousb` package by default because it adds ~400kb to the resulting binary. If you want both, they can be installed thus:
|
||||||
|
|
||||||
go get -v github.com/google/gousb/usb{,id}
|
go get -v github.com/google/gousb{,/usbid}
|
||||||
|
|
||||||
Notes for installation on Windows
|
Notes for installation on Windows
|
||||||
---------------------------------
|
---------------------------------
|
||||||
@@ -78,5 +78,5 @@ Documentation
|
|||||||
=============
|
=============
|
||||||
The documentation can be viewed via local godoc or via the excellent [godoc.org](http://godoc.org/):
|
The documentation can be viewed via local godoc or via the excellent [godoc.org](http://godoc.org/):
|
||||||
|
|
||||||
- [usb](http://godoc.org/github.com/google/gousb/usb)
|
- [usb](http://godoc.org/github.com/google/gousb)
|
||||||
- [usbid](http://godoc.org/pkg/github.com/google/gousb/usbid)
|
- [usbid](http://godoc.org/pkg/github.com/google/gousb/usbid)
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
// #include <libusb.h>
|
// #include <libusb.h>
|
||||||
import "C"
|
import "C"
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
// To enable internal debugging, set the GOUSB_DEBUG environment variable.
|
// To enable internal debugging, set the GOUSB_DEBUG environment variable.
|
||||||
|
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"reflect"
|
"reflect"
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
func (e *endpoint) newStream(size, count int, submit bool) (*stream, error) {
|
func (e *endpoint) newStream(size, count int, submit bool) (*stream, error) {
|
||||||
var ts []transferIntf
|
var ts []transferIntf
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import "testing"
|
import "testing"
|
||||||
|
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
// fake devices connected through the fakeLibusb stack.
|
// fake devices connected through the fakeLibusb stack.
|
||||||
var fakeDevices = []*Descriptor{
|
var fakeDevices = []*Descriptor{
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import "testing"
|
import "testing"
|
||||||
|
|
||||||
@@ -21,7 +21,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
|
|
||||||
"github.com/google/gousb/usb"
|
"github.com/google/gousb"
|
||||||
"github.com/google/gousb/usbid"
|
"github.com/google/gousb/usbid"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -33,14 +33,14 @@ func main() {
|
|||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
// Only one context should be needed for an application. It should always be closed.
|
// Only one context should be needed for an application. It should always be closed.
|
||||||
ctx := usb.NewContext()
|
ctx := gousb.NewContext()
|
||||||
defer ctx.Close()
|
defer ctx.Close()
|
||||||
|
|
||||||
// Debugging can be turned on; this shows some of the inner workings of the libusb package.
|
// Debugging can be turned on; this shows some of the inner workings of the libusb package.
|
||||||
ctx.Debug(*debug)
|
ctx.Debug(*debug)
|
||||||
|
|
||||||
// ListDevices is used to find the devices to open.
|
// ListDevices is used to find the devices to open.
|
||||||
devs, err := ctx.ListDevices(func(desc *usb.Descriptor) bool {
|
devs, err := ctx.ListDevices(func(desc *gousb.Descriptor) bool {
|
||||||
// The usbid package can be used to print out human readable information.
|
// The usbid package can be used to print out human readable information.
|
||||||
fmt.Printf("%03d.%03d %s:%s %s\n", desc.Bus, desc.Address, desc.Vendor, desc.Product, usbid.Describe(desc))
|
fmt.Printf("%03d.%03d %s:%s %s\n", desc.Bus, desc.Address, desc.Vendor, desc.Product, usbid.Describe(desc))
|
||||||
fmt.Printf(" Protocol: %s\n", usbid.Classify(desc))
|
fmt.Printf(" Protocol: %s\n", usbid.Classify(desc))
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
@@ -25,7 +25,7 @@ import (
|
|||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/google/gousb/usb"
|
"github.com/google/gousb"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@@ -41,7 +41,7 @@ var (
|
|||||||
num = flag.Int("read_num", 0, "Number of read transactions to perform. 0 means infinite.")
|
num = flag.Int("read_num", 0, "Number of read transactions to perform. 0 means infinite.")
|
||||||
)
|
)
|
||||||
|
|
||||||
func parseVIDPID(vidPid string) (usb.ID, usb.ID, error) {
|
func parseVIDPID(vidPid string) (gousb.ID, gousb.ID, error) {
|
||||||
s := strings.Split(vidPid, ":")
|
s := strings.Split(vidPid, ":")
|
||||||
if len(s) != 2 {
|
if len(s) != 2 {
|
||||||
return 0, 0, fmt.Errorf("want VID:PID, two 32-bit hex numbers separated by colon, e.g. 1d6b:0002")
|
return 0, 0, fmt.Errorf("want VID:PID, two 32-bit hex numbers separated by colon, e.g. 1d6b:0002")
|
||||||
@@ -54,7 +54,7 @@ func parseVIDPID(vidPid string) (usb.ID, usb.ID, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, 0, fmt.Errorf("PID must be a hexadecimal 32-bit number, e.g. 1d6b")
|
return 0, 0, fmt.Errorf("PID must be a hexadecimal 32-bit number, e.g. 1d6b")
|
||||||
}
|
}
|
||||||
return usb.ID(vid), usb.ID(pid), nil
|
return gousb.ID(vid), gousb.ID(pid), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseBusAddr(busAddr string) (int, int, error) {
|
func parseBusAddr(busAddr string) (int, int, error) {
|
||||||
@@ -77,13 +77,13 @@ func main() {
|
|||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
// Only one context should be needed for an application. It should always be closed.
|
// Only one context should be needed for an application. It should always be closed.
|
||||||
ctx := usb.NewContext()
|
ctx := gousb.NewContext()
|
||||||
defer ctx.Close()
|
defer ctx.Close()
|
||||||
|
|
||||||
ctx.Debug(*debug)
|
ctx.Debug(*debug)
|
||||||
|
|
||||||
var devName string
|
var devName string
|
||||||
var vid, pid usb.ID
|
var vid, pid gousb.ID
|
||||||
var bus, addr int
|
var bus, addr int
|
||||||
switch {
|
switch {
|
||||||
case *vidPID == "" && *busAddr == "":
|
case *vidPID == "" && *busAddr == "":
|
||||||
@@ -108,7 +108,7 @@ func main() {
|
|||||||
|
|
||||||
log.Printf("Scanning for device %q...", devName)
|
log.Printf("Scanning for device %q...", devName)
|
||||||
// ListDevices is used to find the devices to open.
|
// ListDevices is used to find the devices to open.
|
||||||
devs, err := ctx.ListDevices(func(desc *usb.Descriptor) bool {
|
devs, err := ctx.ListDevices(func(desc *gousb.Descriptor) bool {
|
||||||
switch {
|
switch {
|
||||||
case vid == desc.Vendor && pid == desc.Product:
|
case vid == desc.Vendor && pid == desc.Product:
|
||||||
return true
|
return true
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import "io"
|
import "io"
|
||||||
|
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
@@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
@@ -14,7 +14,7 @@
|
|||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
// Package usb provides a wrapper around libusb-1.0.
|
// Package usb provides a wrapper around libusb-1.0.
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
// Context is the libusb context instance.
|
// Context is the libusb context instance.
|
||||||
type Context struct {
|
type Context struct {
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package usb
|
package gousb
|
||||||
|
|
||||||
import "testing"
|
import "testing"
|
||||||
|
|
||||||
@@ -27,17 +27,17 @@ package usbid
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/google/gousb/usb"
|
"github.com/google/gousb"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Describe returns a human readable string describing the vendor and product
|
// Describe returns a human readable string describing the vendor and product
|
||||||
// of the given device.
|
// of the given device.
|
||||||
//
|
//
|
||||||
// The given val must be one of the following:
|
// The given val must be one of the following:
|
||||||
// - *usb.Descriptor "Product (Vendor)"
|
// - *gousb.Descriptor "Product (Vendor)"
|
||||||
func Describe(val interface{}) string {
|
func Describe(val interface{}) string {
|
||||||
switch val := val.(type) {
|
switch val := val.(type) {
|
||||||
case *usb.Descriptor:
|
case *gousb.Descriptor:
|
||||||
if v, ok := Vendors[val.Vendor]; ok {
|
if v, ok := Vendors[val.Vendor]; ok {
|
||||||
if d, ok := v.Product[val.Product]; ok {
|
if d, ok := v.Product[val.Product]; ok {
|
||||||
return fmt.Sprintf("%s (%s)", d, v)
|
return fmt.Sprintf("%s (%s)", d, v)
|
||||||
@@ -53,17 +53,17 @@ func Describe(val interface{}) string {
|
|||||||
// and protocol associated with a device or interface.
|
// and protocol associated with a device or interface.
|
||||||
//
|
//
|
||||||
// The given val must be one of the following:
|
// The given val must be one of the following:
|
||||||
// - *usb.Descriptor "Class (SubClass) Protocol"
|
// - *gousb.Descriptor "Class (SubClass) Protocol"
|
||||||
// - usb.InterfaceSetup "IfClass (IfSubClass) IfProtocol"
|
// - gousb.InterfaceSetup "IfClass (IfSubClass) IfProtocol"
|
||||||
func Classify(val interface{}) string {
|
func Classify(val interface{}) string {
|
||||||
var (
|
var (
|
||||||
class, sub usb.Class
|
class, sub gousb.Class
|
||||||
proto usb.Protocol
|
proto gousb.Protocol
|
||||||
)
|
)
|
||||||
switch val := val.(type) {
|
switch val := val.(type) {
|
||||||
case *usb.Descriptor:
|
case *gousb.Descriptor:
|
||||||
class, sub, proto = val.Class, val.SubClass, val.Protocol
|
class, sub, proto = val.Class, val.SubClass, val.Protocol
|
||||||
case usb.InterfaceSetting:
|
case gousb.InterfaceSetting:
|
||||||
class, sub, proto = val.Class, val.SubClass, val.Protocol
|
class, sub, proto = val.Class, val.SubClass, val.Protocol
|
||||||
default:
|
default:
|
||||||
return fmt.Sprintf("Unknown (%T)", val)
|
return fmt.Sprintf("Unknown (%T)", val)
|
||||||
|
|||||||
@@ -21,20 +21,20 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/google/gousb/usb"
|
"github.com/google/gousb"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
// LinuxUsbDotOrg is one source of files in the format used by this package.
|
// LinuxUsbDotOrg is one source of files in the format used by this package.
|
||||||
LinuxUsbDotOrg = "http://www.linux-usb.org/usb.ids"
|
LinuxUsbDotOrg = "http://www.linux-gousb.org/usb.ids"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
// Vendors stores the vendor and product ID mappings.
|
// Vendors stores the vendor and product ID mappings.
|
||||||
Vendors map[usb.ID]*Vendor
|
Vendors map[gousb.ID]*Vendor
|
||||||
|
|
||||||
// Classes stores the class, subclass and protocol mappings.
|
// Classes stores the class, subclass and protocol mappings.
|
||||||
Classes map[usb.Class]*Class
|
Classes map[gousb.Class]*Class
|
||||||
)
|
)
|
||||||
|
|
||||||
// LoadFromURL replaces the built-in vendor and class mappings with ones loaded
|
// LoadFromURL replaces the built-in vendor and class mappings with ones loaded
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user