| HH-Unispool-Config documentation | Contained in the HH-Unispool-Config distribution. |
HH::Unispool::Config::Entry::Device::7 - UNISPOOL type 7 device
use strict;
use HH::Unispool::Config;
use HH::Unispool::Config::OS;
use HH::Unispool::Config::Scope;
use HH::Unispool::Config::Entry::System;
use HH::Unispool::Config::Entry::Device::6;
use HH::Unispool::Config::Entry::Device::7;
# Create a config from scratch with a _Local_ scope
my $conf = HH::Unispool::Config->new( {
scope => HH::Unispool::Config::Scope->new ( {
scope => [ qw( _Local_) ],
} ),
} );
# Create the _Local_ system and add it to the configuration
my $sysn = HH::Unispool::Config::Entry::System->new( {
name => '_Local_',
local_system_name => 'foo',
network_name => 'foo.bar.org',
os => HH::Unispool::Config::OS->new( {
os => 'Solaris',
} ),
} );
$conf->add_system($sysn);
# Add a type 6 device to _Local_
my $dev = HH::Unispool::Config::Entry::Device::6->new( {
name => 'lp',
filter_name => 'cat',
remote_node_name => 'lp.foo.bar.org',
description => 'lp',
} );
$sysn->add_device($dev);
# Add a type 7 device to _Local_
$dev = HH::Unispool::Config::Entry::Device::7->new( {
name => 'lp-pipe',
filter_name => 'cat',
destination_device => 'lp',
description => 'lp-pipe',
} );
$sysn->add_device($dev);
# Write the configuration
$conf->write('t/config.sample.d7.out');
UNISPOOL type 7 device
Class HH::Unispool::Config::Entry::Device::7 holds information for UNISPOOL type 7 device
Creates a new HH::Unispool::Config::Entry::Device::7 object. OPT_HASH_REF is a hash reference used to pass initialization options. OPT_HASH_REF is mandatory. On error an exception Error::Simple is thrown.
Options for OPT_HASH_REF may include:
destination_devicePassed to set_destination_device(). Mandatory option.
execution_priorityPassed to set_execution_priority(). Defaults to HH::Unispool::Config::ExecPri->new( { execution_priority = '' } )>.
header_namePassed to set_header_name().
initially_spooledPassed to set_initially_spooled(). Defaults to 1.
networkwidePassed to set_networkwide(). Defaults to 1.
save_printfilePassed to set_save_printfile(). Defaults to 0.
trailer_namePassed to set_trailer_name().
Options for OPT_HASH_REF inherited through package HH::Unispool::Config::Entry may include:
namePassed to set_name(). Mandatory option.
Options for OPT_HASH_REF inherited through package HH::Unispool::Config::Entry::Device may include:
descriptionPassed to set_description().
filter_namePassed to set_filter_name(). Mandatory option.
Options for OPT_HASH_REF inherited through package HH::Unispool::Config::Entry::Numbered may include:
diff_numberPassed to set_diff_number(). Defaults to 0.
numberPassed to set_number().
This method is an implementation from package HH::Unispool::Config::Entry::Device. Constructs a new HH::Unispool::Config::Entry object using tokens. TOKENIZER is an HH::Unispool::Config::File::Tokenizer reference. On error an exception Error::Simple is thrown.
This method is an implementation from package HH::Unispool::Config::Entry::Device. Finds differences between two objects. In diff terms, the object is the from object and the specified TO parameter the to object. TO is a reference to an identical object class. Returns an empty string if no difference found and a difference descritpion string otherwise. On error an exception Error::Simple is thrown. Paremeter DIFF_NUMBER if specified, overrules the value of get_diff_number.
This method is inherited from package HH::Unispool::Config::Entry::Device. Returns the description for the device.
Returns the name of device to which the resulting printfile is routed.
Returns the execution priority of the driver process on MPE hosts.
This method is inherited from package HH::Unispool::Config::Entry::Device. Returns the name of the filter file to be used when printfiles for this device are generated.
Returns the control procedure to be executed before printing the printfile.
This method is inherited from package HH::Unispool::Config::Entry. Returns the entry name.
This method is inherited from package HH::Unispool::Config::Entry::Numbered. Returns the entry number.
Returns the control procedure to be executed after printing the printfile.
This method is inherited from package HH::Unispool::Config::Entry::Numbered. Returns whether diff() should consider the number attribtutes or not.
Returns whether an automatic STARTSPOOL must be performed when UNISPOOL is started or not.
Returns whether the device must be made available from each node in the configuration cluster or not.
Returns whether printfiles printed on this device should be saved or not.
This method is inherited from package HH::Unispool::Config::Entry::Device. Set the description for the device. VALUE is the value. On error an exception Error::Simple is thrown.
Set the name of device to which the resulting printfile is routed. VALUE is the value. On error an exception Error::Simple is thrown.
This method is inherited from package HH::Unispool::Config::Entry::Numbered. State that diff() should consider the number attribtutes. VALUE is the value. Default value at initialization is 0. On error an exception Error::Simple is thrown.
Set the execution priority of the driver process on MPE hosts. VALUE is the value. Default value at initialization is HH::Unispool::Config::ExecPri->new( { execution_priority = '' } )>. On error an exception Error::Simple is thrown.
This method is inherited from package HH::Unispool::Config::Entry::Device. Set the name of the filter file to be used when printfiles for this device are generated. VALUE is the value. On error an exception Error::Simple is thrown.
Set the control procedure to be executed before printing the printfile. VALUE is the value. On error an exception Error::Simple is thrown.
State that an automatic STARTSPOOL must be performed when UNISPOOL is started. VALUE is the value. Default value at initialization is 1. On error an exception Error::Simple is thrown.
This method is inherited from package HH::Unispool::Config::Entry. Set the entry name. VALUE is the value. VALUE may not be undef. On error an exception Error::Simple is thrown.
State that the device must be made available from each node in the configuration cluster. VALUE is the value. Default value at initialization is 1. On error an exception Error::Simple is thrown.
This method is inherited from package HH::Unispool::Config::Entry::Numbered. Set the entry number. VALUE is the value. On error an exception Error::Simple is thrown.
State that printfiles printed on this device should be saved. VALUE is the value. Default value at initialization is 0. On error an exception Error::Simple is thrown.
Set the control procedure to be executed after printing the printfile. VALUE is the value. On error an exception Error::Simple is thrown.
This method is an implementation from package HH::Unispool::Config::Entry::Device. Writes the entry to the specified file handle. FILE_HANDLE is an IO::Handle reference. On error an exception Error::Simple is thrown.
HH::Unispool::Config, HH::Unispool::Config::DateFormat, HH::Unispool::Config::Entry, HH::Unispool::Config::Entry::Device, HH::Unispool::Config::Entry::Device::0, HH::Unispool::Config::Entry::Device::1, HH::Unispool::Config::Entry::Device::2, HH::Unispool::Config::Entry::Device::3, HH::Unispool::Config::Entry::Device::4, HH::Unispool::Config::Entry::Device::5, HH::Unispool::Config::Entry::Device::6, HH::Unispool::Config::Entry::Filter, HH::Unispool::Config::Entry::Numbered, HH::Unispool::Config::Entry::RemoteSystem, HH::Unispool::Config::Entry::RemoteSystem::3, HH::Unispool::Config::Entry::RemoteSystem::6, HH::Unispool::Config::Entry::RemoteSystem::7, HH::Unispool::Config::Entry::RemoteSystem::8, HH::Unispool::Config::Entry::System, HH::Unispool::Config::ExecPri, HH::Unispool::Config::File::Token, HH::Unispool::Config::File::Token::Comment, HH::Unispool::Config::File::Token::Comment::Cs, HH::Unispool::Config::File::Token::Comment::Date, HH::Unispool::Config::File::Token::Comment::Device, HH::Unispool::Config::File::Token::Comment::Filter, HH::Unispool::Config::File::Token::Comment::Group, HH::Unispool::Config::File::Token::Comment::Head, HH::Unispool::Config::File::Token::Comment::Misc, HH::Unispool::Config::File::Token::Comment::NetDesc, HH::Unispool::Config::File::Token::Comment::RSys, HH::Unispool::Config::File::Token::Comment::Scope, HH::Unispool::Config::File::Token::Comment::Tail, HH::Unispool::Config::File::Token::Factory, HH::Unispool::Config::File::Token::Numbered, HH::Unispool::Config::File::Token::Numbered::Device, HH::Unispool::Config::File::Token::Numbered::Device::0, HH::Unispool::Config::File::Token::Numbered::Device::1, HH::Unispool::Config::File::Token::Numbered::Device::2, HH::Unispool::Config::File::Token::Numbered::Device::3, HH::Unispool::Config::File::Token::Numbered::Device::4, HH::Unispool::Config::File::Token::Numbered::Device::5, HH::Unispool::Config::File::Token::Numbered::Device::6, HH::Unispool::Config::File::Token::Numbered::Device::7, HH::Unispool::Config::File::Token::Numbered::Device::Group, HH::Unispool::Config::File::Token::Numbered::Device::Info, HH::Unispool::Config::File::Token::Numbered::Device::P, HH::Unispool::Config::File::Token::Numbered::Network, HH::Unispool::Config::File::Token::Numbered::System, HH::Unispool::Config::File::Token::Numbered::System::3, HH::Unispool::Config::File::Token::Numbered::System::6, HH::Unispool::Config::File::Token::Numbered::System::7, HH::Unispool::Config::File::Token::Numbered::System::8, HH::Unispool::Config::File::Token::Numbered::System::Info, HH::Unispool::Config::File::Token::Numbered::X, HH::Unispool::Config::File::Token::Unnumbered, HH::Unispool::Config::File::Token::Unnumbered::Bcs, HH::Unispool::Config::File::Token::Unnumbered::CSN, HH::Unispool::Config::File::Token::Unnumbered::Cs, HH::Unispool::Config::File::Token::Unnumbered::CsBcs, HH::Unispool::Config::File::Token::Unnumbered::Filter, HH::Unispool::Config::File::Token::Unnumbered::Host, HH::Unispool::Config::File::Token::Unnumbered::Misc, HH::Unispool::Config::File::Tokenizer, HH::Unispool::Config::FilterType, HH::Unispool::Config::OS, HH::Unispool::Config::Scope
None known (yet.)
First development: February 2003 Last update: September 2003
Vincenzo Zocca
Copyright 2003 by Vincenzo Zocca
This file is part of the HH::Unispool::Config 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
| HH-Unispool-Config documentation | Contained in the HH-Unispool-Config distribution. |
package HH::Unispool::Config::Entry::Device::7; use 5.006; use base qw( HH::Unispool::Config::Entry::Device ); use strict; use warnings; use AutoLoader qw(AUTOLOAD); use Error qw(:try); use HH::Unispool::Config::ExecPri; # Used by _value_is_allowed our %ALLOW_ISA = ( 'execution_priority' => [ 'HH::Unispool::Config::ExecPri' ], ); # Used by _value_is_allowed our %ALLOW_REF = ( ); # Used by _value_is_allowed our %ALLOW_RX = ( 'destination_device' => [ '^.+$' ], 'header_name' => [ '^.*$' ], 'trailer_name' => [ '^.*$' ], ); # Used by _value_is_allowed our %ALLOW_VALUE = ( ); # Used by _initialize our %DEFAULT_VALUE = ( 'execution_priority' => HH::Unispool::Config::ExecPri->new( { execution_priority => '' } ), 'initially_spooled' => 1, 'networkwide' => 1, 'save_printfile' => 0, ); # Package version our ($VERSION) = '$Revision: 0.3 $' =~ /\$Revision:\s+([^\s]+)/; 1; __END__
sub new_from_tokenizer { my $class = shift; my $tokenizer = shift; # First token must be a HH::Unispool::Config::File::Token::Numbered::Device::7 my $s = $tokenizer->get(); $s->isa('HH::Unispool::Config::File::Token::Numbered::Device::7') || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::new_from_tokenizer, expected a first token from 'TOKENIZER' of class 'HH::Unispool::Config::File::Token::Numbered::Device::7'."); # Fill the initialization option hash my %opt = (); $opt{number} = $s->get_number(); $opt{name} = $s->get_device_name(); $opt{destination_device} = $s->get_remote_device_name(); $opt{initially_spooled} = $s->is_initially_spooled(); $opt{networkwide} = $s->is_networkwide(); $opt{save_printfile} = $s->is_save_printfile(); $opt{execution_priority} = $s->get_execution_priority(); # Allow X and I tokens my $x = undef; my $i = undef; while ( my $tok = $tokenizer->get() ) { if ( ! $tok->isa('HH::Unispool::Config::File::Token::Numbered') || $tok->get_number() != $s->get_number() ) { $tokenizer->unget(); last; } elsif ( $tok->isa('HH::Unispool::Config::File::Token::Numbered::X') ) { defined ($x) && throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::new_from_tokenizer, multiple tokens obtained from 'TOKENIZER' for entry $opt{name}/$opt{number} from class 'HH::Unispool::Config::File::Token::Numbered::X'."); $x = $tok; $opt{header_name} = $x->get_header_name(); $opt{trailer_name} = $x->get_trailer_name(); $opt{filter_name} = $x->get_filter_name(); } elsif ( $tok->isa('HH::Unispool::Config::File::Token::Numbered::Device::Info') ) { defined ($i) && throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::new_from_tokenizer, multiple tokens obtained from 'TOKENIZER' for entry $opt{name}/$opt{number} from class 'HH::Unispool::Config::File::Token::Numbered::Device::Info'."); $i = $tok; $opt{description} = $i->get_description(); } else { throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::new_from_tokenizer, expected tokens from 'TOKENIZER' for entry $opt{name}/$opt{number} from either class 'HH::Unispool::Config::File::Token::Numbered::Device::Info' or 'HH::Unispool::Config::File::Token::Numbered::Network'."); } } # Construct a new object and return it return( HH::Unispool::Config::Entry::Device::7->new(\%opt) ); } sub _initialize { my $self = shift; my $opt = defined($_[0]) ? shift : {}; # Check $opt ref($opt) eq 'HASH' || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::_initialize, first argument must be 'HASH' reference."); # destination_device, SINGLE, mandatory exists( $opt->{destination_device} ) || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::_initialize, option 'destination_device' is mandatory."); $self->set_destination_device( $opt->{destination_device} ); # execution_priority, SINGLE, with default value $self->set_execution_priority( exists( $opt->{execution_priority} ) ? $opt->{execution_priority} : $DEFAULT_VALUE{execution_priority} ); # header_name, SINGLE exists( $opt->{header_name} ) && $self->set_header_name( $opt->{header_name} ); # initially_spooled, BOOLEAN, with default value $self->set_initially_spooled( exists( $opt->{initially_spooled} ) ? $opt->{initially_spooled} : $DEFAULT_VALUE{initially_spooled} ); # networkwide, BOOLEAN, with default value $self->set_networkwide( exists( $opt->{networkwide} ) ? $opt->{networkwide} : $DEFAULT_VALUE{networkwide} ); # save_printfile, BOOLEAN, with default value $self->set_save_printfile( exists( $opt->{save_printfile} ) ? $opt->{save_printfile} : $DEFAULT_VALUE{save_printfile} ); # trailer_name, SINGLE exists( $opt->{trailer_name} ) && $self->set_trailer_name( $opt->{trailer_name} ); # Call the superclass' _initialize $self->SUPER::_initialize($opt); # Return $self return($self); } sub _value_is_allowed { my $name = shift; # Value is allowed if no ALLOW clauses exist for the named attribute if ( ! exists( $ALLOW_ISA{$name} ) && ! exists( $ALLOW_REF{$name} ) && ! exists( $ALLOW_RX{$name} ) && ! exists( $ALLOW_VALUE{$name} ) ) { return(1); } # At this point, all values in @_ must to be allowed CHECK_VALUES: foreach my $val (@_) { # Check ALLOW_ISA if ( ref($val) && exists( $ALLOW_ISA{$name} ) ) { foreach my $class ( @{ $ALLOW_ISA{$name} } ) { &UNIVERSAL::isa( $val, $class ) && next CHECK_VALUES; } } # Check ALLOW_REF if ( ref($val) && exists( $ALLOW_REF{$name} ) ) { exists( $ALLOW_REF{$name}{ ref($val) } ) && next CHECK_VALUES; } # Check ALLOW_RX if ( defined($val) && ! ref($val) && exists( $ALLOW_RX{$name} ) ) { foreach my $rx ( @{ $ALLOW_RX{$name} } ) { $val =~ /$rx/ && next CHECK_VALUES; } } # Check ALLOW_VALUE if ( ! ref($val) && exists( $ALLOW_VALUE{$name} ) ) { exists( $ALLOW_VALUE{$name}{$val} ) && next CHECK_VALUES; } # We caught a not allowed value return(0); } # OK, all values are allowed return(1); } sub diff { my $from = shift; my $to = shift; my $diff_number = shift; $diff_number = $from->is_diff_number() if ( ! defined( $diff_number ) ); # Reference types must be identical if ( ref($from) ne ref($to) ) { my $rf = ref($from); my $rt = ref($to); throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::diff, FROM ($rf) and TO ($rt) reference types differ."); } # Diff message my $diff = $from->SUPER::diff($to, $diff_number); # Diff the destination device if ( $from->get_destination_device() ne $to->get_destination_device() ) { my $ref = ref($from); my $vf = $from->get_destination_device(); my $vt = $to->get_destination_device(); my $name = $from->get_name(); my $number = $from->get_number(); $diff .= "$ref/$name/$number: destination device difference: $vf <-> $vt\n"; } # Diff the execution priority $diff .= $from->get_execution_priority()->diff( $to->get_execution_priority() ); # Diff the header name if ( $from->get_header_name() ne $to->get_header_name() ) { my $ref = ref($from); my $vf = $from->get_header_name(); my $vt = $to->get_header_name(); my $name = $from->get_name(); my $number = $from->get_number(); $diff .= "$ref/$name/$number: header name difference: $vf <-> $vt\n"; } # Diff the initially spooled state if ( $from->is_initially_spooled() != $to->is_initially_spooled() ) { my $ref = ref($from); my $vf = $from->is_initially_spooled(); my $vt = $to->is_initially_spooled(); my $name = $from->get_name(); my $number = $from->get_number(); $diff .= "$ref/$name/$number: initially spooled difference: $vf <-> $vt\n"; } # Diff the networkwide state if ( $from->is_networkwide() != $to->is_networkwide() ) { my $ref = ref($from); my $vf = $from->is_networkwide(); my $vt = $to->is_networkwide(); my $name = $from->get_name(); my $number = $from->get_number(); $diff .= "$ref/$name/$number: networkwide difference: $vf <-> $vt\n"; } # Diff the save printfile state if ( $from->is_save_printfile() != $to->is_save_printfile() ) { my $ref = ref($from); my $vf = $from->is_save_printfile(); my $vt = $to->is_save_printfile(); my $name = $from->get_name(); my $number = $from->get_number(); $diff .= "$ref/$name/$number: save printfile difference: $vf <-> $vt\n"; } # Diff the trailer name if ( $from->get_trailer_name() ne $to->get_trailer_name() ) { my $ref = ref($from); my $vf = $from->get_trailer_name(); my $vt = $to->get_trailer_name(); my $name = $from->get_name(); my $number = $from->get_number(); $diff .= "$ref/$name/$number: trailer name difference: $vf <-> $vt\n"; } # Return diff return($diff); } sub get_destination_device { my $self = shift; return( $self->{HH_Unispool_Config_Entry_Device_7}{destination_device} ); } sub get_execution_priority { my $self = shift; return( $self->{HH_Unispool_Config_Entry_Device_7}{execution_priority} ); } sub get_header_name { my $self = shift; return( $self->{HH_Unispool_Config_Entry_Device_7}{header_name} ); } sub get_trailer_name { my $self = shift; return( $self->{HH_Unispool_Config_Entry_Device_7}{trailer_name} ); } sub is_initially_spooled { my $self = shift; if ( $self->{HH_Unispool_Config_Entry_Device_7}{initially_spooled} ) { return(1); } else { return(0); } } sub is_networkwide { my $self = shift; if ( $self->{HH_Unispool_Config_Entry_Device_7}{networkwide} ) { return(1); } else { return(0); } } sub is_save_printfile { my $self = shift; if ( $self->{HH_Unispool_Config_Entry_Device_7}{save_printfile} ) { return(1); } else { return(0); } } sub set_destination_device { my $self = shift; my $val = shift; # Check if isa/ref/rx/value is allowed &_value_is_allowed( 'destination_device', $val ) || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::set_destination_device, the specified value '$val' is not allowed."); # Assignment $self->{HH_Unispool_Config_Entry_Device_7}{destination_device} = $val; } sub set_execution_priority { my $self = shift; my $val = shift; # Check if isa/ref/rx/value is allowed &_value_is_allowed( 'execution_priority', $val ) || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::set_execution_priority, the specified value '$val' is not allowed."); # Assignment $self->{HH_Unispool_Config_Entry_Device_7}{execution_priority} = $val; } sub set_header_name { my $self = shift; my $val = shift; # Check if isa/ref/rx/value is allowed &_value_is_allowed( 'header_name', $val ) || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::set_header_name, the specified value '$val' is not allowed."); # Assignment $self->{HH_Unispool_Config_Entry_Device_7}{header_name} = $val; } sub set_initially_spooled { my $self = shift; if (shift) { $self->{HH_Unispool_Config_Entry_Device_7}{initially_spooled} = 1; } else { $self->{HH_Unispool_Config_Entry_Device_7}{initially_spooled} = 0; } } sub set_networkwide { my $self = shift; if (shift) { $self->{HH_Unispool_Config_Entry_Device_7}{networkwide} = 1; } else { $self->{HH_Unispool_Config_Entry_Device_7}{networkwide} = 0; } } sub set_save_printfile { my $self = shift; if (shift) { $self->{HH_Unispool_Config_Entry_Device_7}{save_printfile} = 1; } else { $self->{HH_Unispool_Config_Entry_Device_7}{save_printfile} = 0; } } sub set_trailer_name { my $self = shift; my $val = shift; # Check if isa/ref/rx/value is allowed &_value_is_allowed( 'trailer_name', $val ) || throw Error::Simple("ERROR: HH::Unispool::Config::Entry::Device::7::set_trailer_name, the specified value '$val' is not allowed."); # Assignment $self->{HH_Unispool_Config_Entry_Device_7}{trailer_name} = $val; } sub write { my $self = shift; my $fh = shift; # Make the three tokens require HH::Unispool::Config::File::Token::Numbered::Device::7; my $d = HH::Unispool::Config::File::Token::Numbered::Device::7->new( { number => $self->get_number(), device_name => $self->get_name(), remote_device_name => $self->get_destination_device(), initially_spooled => $self->is_initially_spooled(), networkwide => $self->is_networkwide(), save_printfile => $self->is_save_printfile(), execution_priority => $self->get_execution_priority(), } ); require HH::Unispool::Config::File::Token::Numbered::X; my $x = HH::Unispool::Config::File::Token::Numbered::X->new( { number => $self->get_number(), header_name => $self->get_header_name(), trailer_name => $self->get_trailer_name(), filter_name => $self->get_filter_name(), } ); require HH::Unispool::Config::File::Token::Numbered::Device::Info; my $i = HH::Unispool::Config::File::Token::Numbered::Device::Info->new( { number => $self->get_number(), description => $self->get_description(), } ); # Print the tokens $fh->print( $d->write_string() ); $fh->print( $i->write_string() ); $fh->print( $x->write_string() ); }