NAME
Bread::Board::Traversable
VERSION
version 0.33
SYNOPSIS
my $service = $container->fetch('/some/service/path');
my $root = $service->get_root_container;
DESCRIPTION
This role provides the basic functionality to traverse a container / service tree. Instances of classes consuming this role will get a parent-child relationship between them.
ATTRIBUTES
parent
Weak ref to another Bread::Board::Traversable object, read/write accessor (although you should probably not change this value directly in normal code).
METHODS
has_parent
Predicate for the "parent" attribute, true if a parent has been set.
detach_from_parent
Clearer for the "parent" attribute, you should probably not call this method in normal code.
get_root_container
Returns the farthest ancestor of the invocant, i.e. the top-most container this object is a part of.
fetch
my $service = $this->fetch('/absolute/path');
my $service = $this->fetch('relative/path');
my $service = $this->fetch('../relative/path');
Given a (relative or absolute) path to a service or container, this method walks the tree and returns the Bread::Board::Service or Bread::Board::Container instance for that path. Dies if no object can be found for the given path.
Aliases are resolved in this call, by calling aliased_from
until we get an actual service.
AUTHOR
Stevan Little <stevan@iinteractive.com>
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/stevan/BreadBoard/issues
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Infinity Interactive.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.