NAME

Siebel::Srvrmgr::ListParser::Output - base class of srvrmgr output

SYNOPSIS

use Siebel::Srvrmgr::ListParser::Output;

my $output = Siebel::Srvrmgr::ListParser::Output->new({ data_type => 'sometype', 
														raw_data => \@data, 
														cmd_line => 'list something from somewhere'});

print 'Fields pattern: ', $output->get_fields_pattern(), "\n";
$output->store($complete_pathname);

DESCRIPTION

Siebel::Srvrmgr::ListParser::Output is a superclass of output types classes.

It contains only basic attributes and methods that enable specific parsing and serializable methods.

The parse method must be overrided by subclasses or a exception will be raised during object creation.

ATTRIBUTES

data_type

Identifies which kind of data is being given to the class. This is usually used by abstract factory classes to identify which subclass of Siebel::Srvrmgr::ListParser::Output must be created.

This attribute is required during object creation.

raw_data

An array reference with the lines to be processed.

This attribute is required during object creation.

data_parsed

An hash reference with the data parsed from raw_data attribute.

cmd_line

A string of the command that originates the output (the data of raw_data attribute).

This attribute is required during object creation.

fields_pattern

When starting processing the output of list comp command, the header is read and the size of each column is taken from the header of each column. With this information a pattern is build to match each value foreach line read. This attribute will hold the string that describes this pattern (that latter will be used with the unpack() builtin function).

Therefore is really important that the header of srvrmgr program is not removed or the parser will not work properly and probably an exception will be raised by it.

header_regex

The regular expression used to match the header of the list <command> output (the sequence of column names). This is a regular expression reference as returned by qr operator, which means that the regular expression is already optimized.

col_sep

The regular expression used to match the columns separator. Even thought the output has (or should have) a fixed size, the columns are separated by a string. This is a regular expression reference as returned by qr operator, which means that the regular expression is already optimized. col_sep has a builder sub that can be override if the regular expression is different of \s{2,}.

header_cols

An array reference with all the header columns names, in the exact sequence their appear in the output.

METHODS

get_fields_pattern

Returns an string of the attribute fields_pattern.

get_cmd_line

Returns an string of the attribute get_cmd_line.

get_data_parsed

Retuns an hash reference of data_parsed attribute.

set_data_parsed

Sets the data_parsed attribute. It is expected an hash reference as parameter of the method.

get_raw_data

Returns an array reference of the attribute raw_data.

set_raw_data

Sets the raw_data attribute. An array reference is expected as parameter of the method.

load

Method inherited from MooseX::Storage::IO::StorableFile role. It loads a previously serialized Siebel::Srvrmgr::ListParser:Output object into memory.

store

Method inherited from MooseX::Storage::IO::StorableFile role. It stores (serializes) a Siebel::Srvrmgr::ListParser:Output object into a file. A a string of the filename (with complete or not full path) is expected as a parameter.

BUILD

All subclasses of Siebel::Srvrmgr::ListParser::Object will call the method parse right after object instatiation.

parse

The method that actually does the parse of raw_data attribute.

This method should be overrided by subclasses which output does not have a defined header, since this method expects to find a header in the data to be parsed.

_set_col_sep

This is a builder sub to define col_sep attribute. It is quite unlike it will be necessary to change that, but one can override it in subclasses if needed.

This is a "private" method and should be used internally only.

get_col_sep

Getter of col_sep attribute.

_split_fields

Split a output line into fields as defined by get_col_sep method. It expects a string as parameter.

Returns an array reference.

This is a "private" method and should be used internally only.

_set_header

Used to split and define the header fields (see attribute header_cols).

This is a "private" method and should be used internally only but could be overrided by subclasses if it is necessary to change any field before setting the header_cols attribute.

It expects the header line as a parameter, setting the header_cols attribute and returning true in the case of success.

_parse_data

This method is responsible to parse the data from a list command output, after the header was parsed successfully.

This method must be overrided by subclasses since Siebel::Srvrmgr::Output doesn't know anything about how to parse it.

This method in "private" and should be used internally only (more specific, inside the parse method).

The method expects the following parameters:

fields

An array reference with the fields recovered from the output of the list command.

parsed data

An hash reference with all the data already parsed by the parse method.

The method must return true or false depending on the result of parsing the fields and incrementing the parsed data as expected.

_set_header_regex

Expects no parameter. It sets the header_regex attribute.

This method is the builder method of header_regex attribute and must be overrided by subclasses of Siebel::Srvrmgr::ListParser::Output since the superclass knows nothing about the format of the header from the list command output.

CAVEATS

All subclasses of Siebel::Srvrmgr::ListParser::Output expect to have both the header and trailer of executed commands in srvrmgr program. Removing one or both of them will result in parsing errors and probably exceptions.

SEE ALSO

AUTHOR

Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org<>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 of Alceu Rodrigues de Freitas Junior, <arfreitas@cpan.org<>

This file is part of Siebel Monitoring Tools.

Siebel Monitoring Tools 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 3 of the License, or (at your option) any later version.

Siebel Monitoring Tools 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 Siebel Monitoring Tools. If not, see <http://www.gnu.org/licenses/>.