NAME
Config::Model::BackendTrackOrder - Track read order of elements from configuration
VERSION
version 2.144
SYNOPSIS
# inside a backend
use Config::Model::BackendTrackOrder;
has tracker => (
is => 'ro',
isa => 'Config::Model::BackendTrackOrder',
lazy_build => 1,
);
sub _build_tracker {
my $self = shift;
return Config::Model::BackendTrackOrder->new(
backend_obj => $self,
node => $self->node,
) ;
}
# register elements to record user order
$self->tracker->register_element('foo');
$self->tracker->register_element('bar');
# later, when writing data back
foreach my $elt ( $self->tracker->get_ordered_element_names ) {
# write data
}
DESCRIPTION
This module is used by backends to record the order of the configuration elements found in user file. Later these elements can be written back in the file using the same order.
Data are written in canonical order if canonical
method of the "Config::Model::Instance" in instance returns true.
CONSTRUCTOR
THe constructor accepts the following parameters:
- backend_obj
-
The backend object holding this tracker (required).
- node
-
The node holding the backend above
METHODS
register_element
Register the element and keep track of the registration order during initial load
Element registered after initial load (i.e . user modification) are registered using canonical order.
get_ordered_element_names
Returns a list of elements respecting user's order.
Returns the canonical list if Instance canonical attribute is 1.
AUTHOR
Dominique Dumont
COPYRIGHT AND LICENSE
This software is Copyright (c) 2005-2021 by Dominique Dumont.
This is free software, licensed under:
The GNU Lesser General Public License, Version 2.1, February 1999