/usr/lib/perl5/Device/USB/Bus.pm is in libdevice-usb-perl 0.35-2build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 | package Device::USB::Bus;
require 5.006;
use warnings;
use strict;
use Carp;
=head1 NAME
Device::USB::Bus - Use libusb to access USB devices.
=head1 VERSION
Version 0.12
=cut
our $VERSION=0.12;
=head1 SYNOPSIS
This class encapsulates the USB bus structure and provides methods for
retrieving data from it. This class is not meant to be used alone, it is
part of the Device::USB package.
Device:USB:LibUSB provides a Perl wrapper around the libusb library. This
supports Perl code controlling and accessing USB devices.
    use Device::USB;
    my $usb = Device::USB->new();
    foreach my $bus ($usb->list_busses())
    {
        print $bus->dirname(), ":\n";
        foreach my $dev ($bus->devices())
        {
            print "\t", $dev->filename(), "\n";
        }
    }
=head1 DESCRIPTION
This module provides a Perl interface to the bus structures returned by the
libusb library. This library supports a read-only interface to the data libusb
returns about a USB bus.
=head1 FUNCTIONS
=over 4
=item dirname
Return the directory name associated with this bus.
=cut
sub dirname
{
    my $self = shift;
    return $self->{dirname};
}
=item location
Return the location value associated with this bus.
=cut
sub location
{
    my $self = shift;
    return $self->{location};
}
=item devices
In array context, it returns a list of Device::USB::Device objects
representing all of the devices on this bus. In scalar context, it returns a
reference to that array.
=cut
sub devices
{
    my $self = shift;
    return wantarray ? @{$self->{devices}} : $self->{devices};
}
=item find_device_if
Find a particular USB device based on the supplied predicate coderef. If
more than one device would satisfy the predicate, the first one found is
returned.
=over 4
=item pred
the predicate used to select a device
=back
returns a device reference or undef if none was found.
=cut
sub find_device_if
{
    my $self = shift;
    my $pred = shift;
    croak( "Missing predicate for choosing a device.\n" )
        unless defined $pred;
    croak( "Predicate must be a code reference.\n" )
        unless 'CODE' eq ref $pred;
    local $_ = undef;
    foreach($self->devices())
    {
        return $_ if $pred->();
    }
    return;
}
=item list_devices_if
This method provides a flexible interface for finding devices. It
takes a single coderef parameter that is used to test each discovered
device. If the coderef returns a true value, the device is returned in the
list of matching devices, otherwise it is not.
=over 4
=item pred
coderef to test devices.
=back
For example,
    my @devices = $bus->list_devices_if(
        sub { Device::USB::CLASS_HUB == $_->bDeviceClass() }
    );
Returns all USB hubs found on this bus. The device to test is available to
the coderef in the C<$_> variable for simplicity.
=cut
sub list_devices_if
{
    my $self = shift;
    my $pred = shift;
    croak( "Missing predicate for choosing devices.\n" )
        unless defined $pred;
    croak( "Predicate must be a code reference.\n" )
        unless 'CODE' eq ref $pred;
    local $_ = undef;
    my @devices = grep { $pred->() } $self->devices();
    return wantarray ? @devices : \@devices;
}
=back
=head1 DIAGNOSTICS
This is an explanation of the diagnostic and error messages this module
can generate.
=head1 DEPENDENCIES
This module depends on the Carp and Device::USB, as well as
the strict and warnings pragmas. Obviously, libusb must be available since
that is the entire reason for the module's existence.
=head1 AUTHOR
G. Wade Johnson (wade at anomaly dot org)
Paul Archer (paul at paularcher dot org)
Houston Perl Mongers Group
=head1 BUGS
Please report any bugs or feature requests to
C<bug-device-usb@rt.cpan.org>, or through the web interface at
L<http://rt.cpan.org/NoAuth/ReportBug.html?Device::USB>.
I will be notified, and then you'll automatically be notified of progress on
your bug as I make changes.
=head1 ACKNOWLEDGEMENTS
Thanks go to various members of the Houston Perl Mongers group for input
on the module. But thanks mostly go to Paul Archer who proposed the project
and helped with the development.
Thanks also go to Josep Monés Teixidor, Mike McCauley, and Tony Awtrey for
spotting, reporting, and (sometimes) fixing bugs.
=head1 COPYRIGHT & LICENSE
Copyright 2006 Houston Perl Mongers
This program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.
=cut
1;
 |