| Net-DBus documentation | Contained in the Net-DBus distribution. |
Net::DBus::Binding::Message - Base class for messages
Sending a message
my $msg = new Net::DBus::Binding::Message::Signal; my $iterator = $msg->iterator; $iterator->append_byte(132); $iterator->append_int32(14241); $connection->send($msg);
Provides a base class for the different kinds of message that can be sent/received. Instances of this class are never instantiated directly, rather one of the four sub-types Net::DBus::Binding::Message::Signal, Net::DBus::Binding::Message::MethodCall, Net::DBus::Binding::Message::MethodReturn, Net::DBus::Binding::Message::Error should be used.
The following constants are defined in this module. They are not exported into the caller's namespace & thus must be referenced with their fully qualified package names
Constant representing the signature value associated with the array data type.
Constant representing the signature value associated with the boolean data type.
Constant representing the signature value associated with the byte data type.
Constant representing the signature value associated with the dictionary entry data type.
Constant representing the signature value associated with the IEEE double precision floating point data type.
Constant representing the signature value associated with the signed 16 bit integer data type.
Constant representing the signature value associated with the signed 32 bit integer data type.
Constant representing the signature value associated with the signed 64 bit integer data type.
Constant representing the signature value associated with the object path data type.
Constant representing the signature value associated with the UTF-8 string data type.
Constant representing the signature value associated with the signature data type.
Constant representing the signature value associated with the struct data type.
Constant representing the signature value associated with the unsigned 16 bit integer data type.
Constant representing the signature value associated with the unsigned 32 bit integer data type.
Constant representing the signature value associated with the unsigned 64 bit integer data type.
Constant representing the signature value associated with the variant data type.
Creates a new message object, initializing it with the underlying C
message object given by the message object. This constructor is
intended for internal use only, instead refer to one of the four
sub-types for this class for specific message types
Retrieves the type code for this message. The returned value corresponds
to one of the four Net::DBus::Binding::Message::MESSAGE_TYPE_* constants.
Retrieves the name of the interface targetted by this message, possibly an empty string if there is no applicable interface for this message.
Retrieves the object path associated with the message, possibly an empty string if there is no applicable object for this message.
Retrieves the uniqe or well-known bus name for client intended to be the recipient of the message. Possibly returns an empty string if the message is being broadcast to all clients.
Retireves the unique name of the client sending the message
Retrieves the unique serial number of this message. The number is guarenteed unique for as long as the connection over which the message was sent remains open. May return zero, if the message is yet to be sent.
For method calls, retrieves the name of the method to be invoked, while for signals, retrieves the name of the signal.
Retrieves a string representing the type signature of the values packed into the body of the message.
Set the name of the client sending the message. The name must be the unique name of the client.
Set the name of the intended recipient of the message. This is typically used for signals to switch them from broadcast to unicast.
Retrieves an iterator which can be used for reading or
writing fields of the message. The returned object is
an instance of the Net::DBus::Binding::Iterator class.
Gets the flag indicating whether the message is expecting a reply to be sent.
Toggles the flag indicating whether the message is expecting a reply to be sent. All method call messages expect a reply by default. By toggling this flag the communication latency is reduced by removing the need for the client to wait
De-marshall all the values in the body of the message, using the message signature to identify data types. The values are returned as a list.
Append a set of values to the body of the message. Values will be encoded as either a string, list or dictionary as appropriate to their Perl data type. For more specific data typing needs, the Net::DBus::Binding::Iterator object should be used instead.
Net::DBus::Binding::Server, Net::DBus::Binding::Connection, Net::DBus::Binding::Message::Signal, Net::DBus::Binding::Message::MethodCall, Net::DBus::Binding::Message::MethodReturn, Net::DBus::Binding::Message::Error
Daniel Berrange <dan@berrange.com>
Copyright 2004 by Daniel Berrange
| Net-DBus documentation | Contained in the Net-DBus distribution. |
# -*- perl -*- # # Copyright (C) 2004-2006 Daniel P. Berrange # # This program is free software; You can redistribute it and/or modify # it under the same terms as Perl itself. Either: # # a) the GNU General Public License as published by the Free # Software Foundation; either version 2, or (at your option) any # later version, # # or # # b) the "Artistic License" # # The file "COPYING" distributed along with this file provides full # details of the terms and conditions of the two licenses.
package Net::DBus::Binding::Message; use 5.006; use strict; use warnings; use Net::DBus::Binding::Iterator; use Net::DBus::Binding::Message::Signal; use Net::DBus::Binding::Message::MethodCall; use Net::DBus::Binding::Message::MethodReturn; use Net::DBus::Binding::Message::Error;
sub new { my $proto = shift; my $class = ref($proto) || $proto; my %params = @_; my $self = {}; $self->{message} = exists $params{message} ? $params{message} : (Net::DBus::Binding::Message::_create(exists $params{type} ? $params{type} : die "type parameter is required")); bless $self, $class; if ($class eq "Net::DBus::Binding::Message") { $self->_specialize; } return $self; } sub _specialize { my $self = shift; my $type = $self->get_type; if ($type == &Net::DBus::Binding::Message::MESSAGE_TYPE_METHOD_CALL) { bless $self, "Net::DBus::Binding::Message::MethodCall"; } elsif ($type == &Net::DBus::Binding::Message::MESSAGE_TYPE_METHOD_RETURN) { bless $self, "Net::DBus::Binding::Message::MethodReturn"; } elsif ($type == &Net::DBus::Binding::Message::MESSAGE_TYPE_ERROR) { bless $self, "Net::DBus::Binding::Message::Error"; } elsif ($type == &Net::DBus::Binding::Message::MESSAGE_TYPE_SIGNAL) { bless $self, "Net::DBus::Binding::Message::Signal"; } else { warn "Unknown message type $type\n"; } }
sub get_type { my $self = shift; return $self->{message}->dbus_message_get_type; }
sub get_interface { my $self = shift; return $self->{message}->dbus_message_get_interface; }
sub get_path { my $self = shift; return $self->{message}->dbus_message_get_path; }
sub get_destination { my $self = shift; return $self->{message}->dbus_message_get_destination; }
sub get_sender { my $self = shift; return $self->{message}->dbus_message_get_sender; }
sub get_serial { my $self = shift; return $self->{message}->dbus_message_get_serial; }
sub get_member { my $self = shift; return $self->{message}->dbus_message_get_member; }
sub get_signature { my $self = shift; return $self->{message}->dbus_message_get_signature; }
sub set_sender { my $self = shift; $self->{message}->dbus_message_set_sender(@_); }
sub set_destination { my $self = shift; $self->{message}->dbus_message_set_destination(@_); }
sub iterator { my $self = shift; my $append = @_ ? shift : 0; if ($append) { return Net::DBus::Binding::Message::_iterator_append($self->{message}); } else { return Net::DBus::Binding::Message::_iterator($self->{message}); } }
sub get_no_reply { my $self = shift; return $self->{message}->dbus_message_get_no_reply; }
sub set_no_reply { my $self = shift; my $flag = shift; $self->{message}->dbus_message_set_no_reply($flag); }
sub get_args_list { my $self = shift; my @ret; my $iter = $self->iterator; if ($iter->get_arg_type() != &Net::DBus::Binding::Message::TYPE_INVALID) { do { push @ret, $iter->get(); } while ($iter->next); } return @ret; }
sub append_args_list { my $self = shift; my @args = @_; my $iter = $self->iterator(1); foreach my $arg (@args) { $iter->append($arg); } } # To keep autoloader quiet sub DESTROY { } sub AUTOLOAD { # This AUTOLOAD is used to 'autoload' constants from the constant() # XS function. my $constname; our $AUTOLOAD; ($constname = $AUTOLOAD) =~ s/.*:://; die "&Net::DBus::Binding::Message::constant not defined" if $constname eq '_constant'; if (!exists $Net::DBus::Binding::Message::_constants{$constname}) { die "no such constant \$Net::DBus::Binding::Message::$constname"; } { no strict 'refs'; *$AUTOLOAD = sub { $Net::DBus::Binding::Message::_constants{$constname} }; } goto &$AUTOLOAD; } 1;