#include "uvc.h" // NOLINT #include #include // #define ENABLE_DEBUG_SPAM MYNTEYE_BEGIN_NAMESPACE namespace uvc { static void check(const char *call, uvc_error_t status) { LOG_IF(FATAL, status < 0) << call << "(...) returned " << uvc_strerror(status); } #define CALL_UVC(name, ...) check(#name, name(__VA_ARGS__)) struct context { uvc_context_t *ctx; context() : ctx() { CALL_UVC(uvc_init, &ctx, nullptr); } ~context() { if (ctx) uvc_exit(ctx); } }; struct device { const std::shared_ptr parent; uvc_device_t *uvcdevice; uvc_device_handle_t *handle = nullptr; int vid, pid; // uvc_stream_ctrl_t ctrl; // uint8_t unit; // video_channel_callback callback = nullptr; device(std::shared_ptr parent, uvc_device_t *uvcdevice) : parent(parent), uvcdevice(uvcdevice) { open(); uvc_device_descriptor_t *desc; CALL_UVC(uvc_get_device_descriptor, uvcdevice, &desc); vid = desc->idVendor; pid = desc->idProduct; uvc_free_device_descriptor(desc); } ~device() { if (handle) uvc_close(handle); if (uvcdevice) uvc_unref_device(uvcdevice); } void open() { if (!handle) CALL_UVC(uvc_open, uvcdevice, &handle); } }; std::shared_ptr create_context() { return std::make_shared(); } std::vector> query_devices( std::shared_ptr context) { std::vector> devices; uvc_device_t **list; CALL_UVC(uvc_get_device_list, context->ctx, &list); for (auto it = list; *it; ++it) { try { auto dev = std::make_shared(context, *it); devices.push_back(dev); } catch (std::runtime_error &e) { LOG(WARNING) << "usb:" << static_cast(uvc_get_bus_number(*it)) << ':' << static_cast(uvc_get_device_address(*it)) << ": " << e.what(); } } uvc_free_device_list(list, 1); return devices; } int get_vendor_id(const device &device) { return device.vid; } int get_product_id(const device &device) { return device.pid; } } // namespace uvc MYNTEYE_END_NAMESPACE