NAME
PDK::Content::Role - A Moose role for content parsing and management
SYNOPSIS
package MyContentParser;
use Moose;
with 'PDK::Content::Role';
# Implement required methods
sub config { ... }
sub confContent { ... }
sub cursor { ... }
sub goToHead { ... }
sub nextLine { ... }
sub prevLine { ... }
sub nextUnParsedLine { ... }
sub backtrack { ... }
sub ignore { ... }
sub getUnParsedLines { ... }
DESCRIPTION
PDK::Content::Role is a Moose role that defines a common interface for content parsing and management. It provides a set of attributes and required methods that implementing classes must define to handle configuration content effectively.
ATTRIBUTES
id
An integer representing the unique identifier of the device. This attribute is required and read-only.
name
A string representing the name of the device, used for display and identification. This attribute is required and read-only.
type
A string representing the type or category of the device. This attribute is required and read-only.
sign
A string representing the configuration signature, used to verify the integrity of the configuration. This attribute is required and read-only.
timestamp
A string representing the timestamp of when the configuration was created or modified. This attribute is required and read-only.
lineParsedFlags
An arrayref of integers representing the parse status of each line in the configuration. It is built using the _buildLineParsedFlags
method, which must be implemented by the consuming class.
debug
An integer representing the debug level, used to control the output of debug information. This attribute is optional and read-only.
REQUIRED METHODS
The following methods must be implemented by any class consuming this role:
config
Method to get or set the configuration.
confContent
Method to get the configuration content as text.
cursor
Method to get or set the current parsing position.
goToHead
Method to reset the parsing position to the beginning.
nextLine
Method to move to the next line and return its content.
prevLine
Method to move to the previous line and return its content.
nextUnParsedLine
Method to find and return the next unparsed line, skipping already parsed lines.
backtrack
Method to return to the previous parsing position.
ignore
Method to skip the current line.
getUnParsedLines
Method to return all unparsed lines.
AUTHOR
[Your Name or Organization]
LICENSE
This library is free software. You can redistribute it and/or modify it under the same terms as Perl itself.