NAME
Protocol::DBus - D-Bus in pure Perl
SYNOPSIS
my $dbus = Protcol::DBus::Client::system();
For blocking I/O:
$dbus->do_authn();
$dbus->send_call(
path => '/org/freedesktop/DBus',
interface => 'org.freedesktop.DBus.Properties',
member => 'GetAll',
destination => 'org.freedesktop.DBus',
signature => 's',
body => [ 'org.freedesktop.DBus' ],
on_return => sub { my ($msg) = @_ },
);
my $msg = $dbus->get_message();
For non-blocking I/O:
$dbus->blocking(0);
my $fileno = $dbus->fileno();
# You can use whatever polling method you prefer;
# the following is just for demonstration:
vec( my $mask, $fileno, 1 ) = 1;
while (!$dbus->do_authn()) {
if ($dbus->authn_pending_send()) {
select( undef, my $wout = $mask, undef, undef );
}
else {
select( my $rout = $mask, undef, undef, undef );
}
}
$dbus->send_call( .. ); # same parameters as above
while (1) {
my $wout = $dbus->pending_send() || q<>;
$wout &&= $mask;
select( my $rout = $mask, $wout, undef, undef );
if ($wout =~ tr<\0><>c) {
$dbus->flush_write_queue();
}
if ($rout =~ tr<\0><>c) {
# It’s critical to get_message() until undef is returned.
1 while $dbus->get_message();
}
}
DESCRIPTION
This is an original, pure-Perl implementation of client logic for the D-Bus protocol.
Right now this distribution is an experimental effort. If you use it in your project, be sure to check the changelog before deploying a new version. Please file bug reports as appropriate.
See Protocol::DBus::Client and the above sample for a starting point.
EXAMPLES
See the distribution’s examples/ directory.