package HH::Unispool::Config::File::Token::Numbered::System::8; use 5.006; use base qw( HH::Unispool::Config::File::Token::Numbered::System ); use strict; use warnings; use AutoLoader qw(AUTOLOAD); use Error qw(:try); use HH::Unispool::Config::File::Token qw( :rx :frm ); # Package version our ($VERSION) = '$Revision: 0.3 $' =~ /\$Revision:\s+([^\s]+)/; 1; __END__ =head1 NAME HH::Unispool::Config::File::Token::Numbered::System::8 - system type C<8> system I token =head1 SYNOPSIS Application programmers don't need to use this class and API programmers read code. =head1 ABSTRACT system type C<8> system I token =head1 DESCRIPTION C contans system type C<8> system I token information. =head1 CONSTRUCTOR =over =item new(OPT_HASH_REF) Creates a new C object. C is a hash reference used to pass initialization options. C is mandatory. On error an exception C is thrown. Options for C inherited through package B> may include: =over =item B> Passed to L. =back Options for C inherited through package B> may include: =over =item B> Passed to L. =back Options for C inherited through package B> may include: =over =item B> Passed to L. =item B> Passed to L. =item B> Passed to L. =item B> Passed to L. =item B> Passed to L. =item B> Passed to L. =item B> Passed to L. Mandatory option. =item B> Passed to L. =item B> Passed to L. =back =item new_from_string(LINE) Creates a new object from the specified Unispool config file line string. =back =head1 METHODS =over =item get_acct() This method is inherited from package C. Returns the remote login account (is not available on development system used). =item get_apass() This method is inherited from package C. Returns the account password (is not available on development system used). =item get_block_delay() This method is inherited from package C. Returns the time in seconds UNISPOOL should pause between sending two blocks. =item get_execution_priority() This method is inherited from package C. Returns the execution priority of the driver process on MPE hosts. =item get_input_line_number() This method is inherited from package C. Returns the line number from from which the token is read. =item get_number() This method is inherited from package C. Returns the number of the entry. =item get_remote_system_name() This method is inherited from package C. Returns the unique name for the remote system. =item get_timeout() This method is inherited from package C. Returns the delay before closing the link after transfering the last request (in seconds) (is not available on development system used). =item get_upass() This method is inherited from package C. Returns the user paccword (is not available on development system used). =item is_high_priority_login() This method is inherited from package C. Returns whether the login must be high priotity (is not available on development system used) or not. =item is_initially_open() This method is inherited from package C. Returns whether the communication link should be opened at the moment UNISPOOL is started or not. =item read_string(LINE) This method is overloaded from package C. Reads the Unispool config file token from a line string. C is a plain line string. On error an exception C is thrown. =item set_acct(VALUE) This method is inherited from package C. Set the remote login account (is not available on development system used). C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^.*$ =back =back =item set_apass(VALUE) This method is inherited from package C. Set the account password (is not available on development system used). C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^.*$ =back =back =item set_block_delay(VALUE) This method is inherited from package C. Set the time in seconds UNISPOOL should pause between sending two blocks. C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^\d*$ =back =back =item set_execution_priority(VALUE) This method is inherited from package C. Set the execution priority of the driver process on MPE hosts. C is the value. On error an exception C is thrown. =over =item VALUE must be a (sub)class of: =over =item HH::Unispool::Config::ExecPri =back =back =item set_high_priority_login(VALUE) This method is inherited from package C. State that the login must be high priotity (is not available on development system used). C is the value. On error an exception C is thrown. =item set_initially_open(VALUE) This method is inherited from package C. State that the communication link should be opened at the moment UNISPOOL is started. C is the value. On error an exception C is thrown. =item set_input_line_number(VALUE) This method is inherited from package C. Set the line number from from which the token is read. C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^\d*$ =back =back =item set_number(VALUE) This method is inherited from package C. Set the number of the entry. C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^\d*$ =back =back =item set_remote_system_name(VALUE) This method is inherited from package C. Set the unique name for the remote system. C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^.+$ =back =back =item set_timeout(VALUE) This method is inherited from package C. Set the delay before closing the link after transfering the last request (in seconds) (is not available on development system used). C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^\d*$ =back =back =item set_upass(VALUE) This method is inherited from package C. Set the user paccword (is not available on development system used). C is the value. On error an exception C is thrown. =over =item VALUE must match regular expression: =over =item ^.*$ =back =back =item write_string() This method is overloaded from package C. Returns a Unispool config file token line string. =back =head1 SEE ALSO L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L, L =head1 BUGS None known (yet.) =head1 HISTORY First development: February 2003 Last update: September 2003 =head1 AUTHOR Vincenzo Zocca =head1 COPYRIGHT Copyright 2003 by Vincenzo Zocca =head1 LICENSE This file is part of the C module hierarchy for Perl by Vincenzo Zocca. The HH::Unispool::Config module hierarchy 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. The HH::Unispool::Config module hierarchy is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with the HH::Unispool::Config module hierarchy; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA =cut sub read_string { my $self = shift; my $line = shift; # Parse line for name my ($number, $remote_system_name, $tail) = $line =~ /$USP_S8_RX/; defined($number) || throw Error::Simple("ERROR: HH::Unispool::Config::File::Token::Numbered::System::8::read_string, parameter 'LINE' does not match the regular expression for this token's line string."); $remote_system_name =~ s/\s*$//; my @tail = $self->_split_tail($tail); my $block_delay = $tail[6]; my $flags = $tail[7]; my $exec = $tail[8]; # Set attributes $self->set_number($number); defined($remote_system_name) && $self->set_remote_system_name($remote_system_name); defined($block_delay) && $self->set_block_delay($block_delay); defined($flags) && $self->set_initially_open( $flags =~ /i/i ); defined($flags) && $self->set_high_priority_login( $flags =~ /h/i ); require HH::Unispool::Config::ExecPri; defined($exec) && $self->set_execution_priority( HH::Unispool::Config::ExecPri->new( {execution_priority=> $exec} ) ); } sub write_string { my $self = shift; # Make string and return it my $flags = ''; $flags .= $self->is_high_priority_login() ? 'H' : ' '; $flags .= $self->is_initially_open() ? 'I' : ' '; return( sprintf( $USP_S8_FRM, $self->get_number() || 0, $self->get_remote_system_name() || '', $self->get_block_delay() || 0, $flags || '', $self->get_execution_priority()->get_execution_priority() || '', ) ); }