blob: 989ccb688c0c272ec60ab522189640a1b235bfc2 [file] [log] [blame]
#
# Copyright (c) 2006- Facebook
# Distributed under the Thrift Software License
#
# See accompanying file LICENSE or visit the Thrift site at:
# http://developers.facebook.com/thrift/
#
# package - thrift.transport
# author - T Jake Luciani <jakers@gmail.com>
# author - Mark Slee <mcslee@facebook.com>
#
require 5.6.0;
use strict;
use warnings;
use Thrift;
#
# Transport exceptions
#
package TTransportException;
use base('Thrift::TException');
use constant UNKNOWN => 0;
use constant NOT_OPEN => 1;
use constant ALREADY_OPEN => 2;
use constant TIMED_OUT => 3;
use constant END_OF_FILE => 4;
sub new{
my $classname = shift;
my $self = $classname->SUPER::new(@_);
return bless($self,$classname);
}
package Thrift::Transport;
#
# Whether this transport is open.
#
# @return boolean true if open
#
sub isOpen
{
die "abstract";
}
#
# Open the transport for reading/writing
#
# @throws TTransportException if cannot open
#
sub open
{
die "abstract";
}
#
# Close the transport.
#
sub close
{
die "abstract";
}
#
# Read some data into the array.
#
# @param int $len How much to read
# @return string The data that has been read
# @throws TTransportException if cannot read any more data
#
sub read
{
my ($len);
die("abstract");
}
#
# Guarantees that the full amount of data is read.
#
# @return string The data, of exact length
# @throws TTransportException if cannot read data
#
sub readAll
{
my $self = shift;
my $len = shift;
my $data = '';
my $got = 0;
while (($got = length($data)) < $len) {
$data .= $self->read($len - $got);
}
return $data;
}
#
# Writes the given data out.
#
# @param string $buf The data to write
# @throws TTransportException if writing fails
#
sub write
{
my ($buf);
die "abstract";
}
#
# Flushes any pending data out of a buffer
#
# @throws TTransportException if a writing error occurs
#
sub flush {}
1;