Tidy up naming/organization

Cleans up naming to be more ergonomic and obvious.

Change-Id: I16a4ebfd833eec66a1057dd40f8836b7e7b7c721
5 files changed
tree: 828e350795fa99946976c59f3c4705113da5ccd0
  1. include/
  2. linux/
  3. .gitignore
  4. AUTHORS
  5. BUILD.bazel
  6. CONTRIBUTING.md
  7. extensions.bzl
  8. libusb.BUILD
  9. LICENSE
  10. MODULE.bazel
  11. OWNERS
  12. README.md
README.md

rules_libusb

A small wrapper Bazel module that builds libusb from sources. Supports Windows, macOS, and Linux.

Getting Started

At this time, rules_libusb only supports bzlmod projects. Legacy WORKSPACE projects are not explicitly supported.

blzmod

Add rules_libusb to your MODULE.bazel file:

bazel_dep(name = "rules_libusb", version="0.1.0-rc1")

libusb = use_extension("@rules_libusb//:extensions.bzl", "libusb")
# Versioning constraints are optional.
libusb.source_release(min_version = "1.0.27")
use_repo(libusb, "libusb")

Then add to the tool that requires libusb:

cc_binary(
    name = "my_tool",
    srcs = ["main.cpp"],
    deps = ["@libusb//:libusb_core"],  # Required for headers.
    dynamic_deps = ["@libusb//:libusb"],  # Link against shared lib.
)

Note: source_release constraints follow bzlmod behavior of minimal version selection.

Building this repo

To build this repo, run:

bazel build @libusb//:libusb