| Net-DRI documentation | Contained in the Net-DRI distribution. |
Net::DRI::Data::Raw - Encapsulating raw data for Net::DRI
Please see the README file for details.
For now, support questions should be sent to:
<netdri@dotandco.com>
Please also see the SUPPORT file in the distribution.
<http://www.dotandco.com/services/software/Net-DRI/>
Patrick Mevzek, <netdri@dotandco.com>
Copyright (c) 2005-2010 Patrick Mevzek <netdri@dotandco.com>. All rights reserved.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
See the LICENSE file that comes with this distribution for more details.
| Net-DRI documentation | Contained in the Net-DRI distribution. |
## Domain Registry Interface, Encapsulating raw data ## ## Copyright (c) 2005-2010 Patrick Mevzek <netdri@dotandco.com>. All rights reserved. ## ## This file is part of Net::DRI ## ## Net::DRI is free software; you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by ## the Free Software Foundation; either version 2 of the License, or ## (at your option) any later version. ## ## See the LICENSE file that comes with this distribution for more details. # # # ######################################################################################### package Net::DRI::Data::Raw; use strict; use warnings; use Data::Dumper (); use Net::DRI::Exception; use base qw(Class::Accessor::Fast); __PACKAGE__->mk_ro_accessors(qw(type data hint)); our $VERSION=do { my @r=(q$Revision: 1.11 $=~/\d+/g); sprintf("%d".".%02d" x $#r, @r); };
#################################################################################################### sub new { my $class=shift; my ($type,$data,$hint)=@_; ## type=1, data=ref to array ## type=2, data=string ## type=3, data=ref to string NOTIMPL ## type=4, data=path to local file NOTIMPL ## type=5, data=object with a as_string method ## type=6, data=complex object in a ref array my $self={type => $type, data => $data, hint => $hint || '', }; bless($self,$class); return $self; } sub new_from_array { my $class=shift; my @a=map { my $f=$_; $f=~s/[\r\n\s]+$//; $f; } (ref($_[0]))? @{$_[0]} : @_; return $class->new(1,\@a); } sub new_from_string { return shift->new(2,@_); } sub new_from_xmlstring { return shift->new(2,$_[0],'xml'); } sub new_from_object { return shift->new(5,@_); } #################################################################################################### sub as_string { my $self=shift; my $data=$self->data(); if ($self->type()==1) { return join("\n",@$data)."\n"; } if ($self->type()==2) { $data=~s/\r\n/\n/g; return $data; } if ($self->type()==5) { Net::DRI::Exception::err_method_not_implemented('as_string in '.ref($data)) unless $data->can('as_string'); return $data->as_string(); } if ($self->type()==6) { return Data::Dumper->new($data)->Indent(2)->Varname('')->Quotekeys(0)->Sortkeys(1)->Dump(); } } sub last_line { my $self=shift; if ($self->type()==1) { my $data=$self->data(); return $data->[$#$data]; ## see above } if ($self->type()==2) { my @a=$self->as_array(); return $a[-1]; } } sub as_array { my $self=shift; if ($self->type()==1) { return @{$self->data()}; } if ($self->type()==2) { return split(/\r?\n/,$self->data()); } } #################################################################################################### 1;