NAME

Hessian::Translator - Base class for Hessian serialization/deserialization.

SYNOPSIS

my $translator = Hessian::Translator->new( version => 1 );

my $hessian_string = "S\x00\x05hello";
$translator->input_string($hessian_string);
my $output = $translator->deserialize_message();


# Apply serialization methods to the object.
Hessian::Serializer->meta()->apply($translator);

DESCRIPTION

Hessian::Translator is made to act as the base class (or whatever this is called in Moose terminology) for serialization/deserialization methods.

On its own, this class really only provides some of the more basic functions required for Hessian processing such as the type list for datatypes, the reference list for maps, objects and arrays; and the object class definition list. Integration of the respective serialization and deserialization behaviours only takes place when needed. Depending on how the translator is initialized and which methods are called on the object, it is possibly to specialize the object for either Hessian 1.0 or Hessian 2.0 processing and to selectively include methods for serialization and or deserialization.

INTERFACE

BUILD

Not to be called directly.

new

version

Allowed values are 1 or 2 and correspond to the respective Hessian protocol version.

input_string

string

The Hessian encoded string to be decoded. This may represent an entire message or a simple scalar or datastructure. Note that the first application of this method causes the Hessian::Deserializer role to be applied to this class.

version

Retrieves the current version for which this client was initialized. See "new".

class_definitions

Provides access to the internal class definition list.

type_list

Provides access to the internal type list.

reference_list

Provides access to the internal list of references.

serializer

Causes the Hessian::Serializer methods to be applied to the current object.

DEPENDENCIES

Moose