The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Tree::From::ObjArray - Build a tree of objects from a nested array of objects

VERSION

This document describes version 0.001 of Tree::From::ObjArray (from Perl distribution Tree-From-ObjArray), released on 2021-05-06.

SYNOPSIS

In your tree node class My/Person.pm:

package My::Person;

sub new {
    my $class = shift;
    my %args = @_;
    bless \%args, $class;
}

sub parent {
    my $self = shift;
    $self->{_parent} = $_[0] if $@;
    $self->{_parent};
}

sub children {
    my $self = shift;
    $self->{_children} = $_[0] if $@;
    $self->{_children};
}

In your code to build a tree:

use Tree::From::ObjArray qw(build_tree_from_obj_array);

# require all the used classes
use My::Person;
use My::MarriedPerson;
use My::KidPerson;

my $family_tree = build_tree_from_obj_array([
    My::Person->new(name => 'Andi', age => 60), [
      My::Person->new(name => 'Budi', age => 30),
      My::MarriedPerson->new(name => 'Cinta'), [
        My::KidPerson->new(name => 'Deni'),
        My::KidPerson->new(name => 'Eno'),
      ],
   ]
]);

This tree is visualized as follows:

Andi
  ├─Budi
  └─Cinta
      ├─Deni
      └─Eno

DESCRIPTION

Building a tree manually can be tedious: you have to connect the parent and the children nodes together:

my $root = My::TreeNode->new(...);
my $child1 = My::TreeNode->new(...);
my $child2 = My::TreeNode->new(...);

$root->children([$child1, $child2]);
$child1->parent($root);
$child2->parent($root);

my $grandchild1 = My::TreeNode->new(...);
...

This module provides a convenience function to build a tree of objects in a single command. It connects the parent and children nodes for you.

The class can be any class that provides parent and children methods. See Role::TinyCommons::Tree::Node for more details.

FUNCTIONS

build_tree_from_obj_array($obj_array) => obj

This is basically Role::TinyCommons::Tree::FromObjArray's new_from_obj_array presented as a function. See the role's documentation for more details on what you can put in $obj_array.

HOMEPAGE

Please visit the project's homepage at https://metacpan.org/release/Tree-From-ObjArray.

SOURCE

Source repository is at https://github.com/perlancar/perl-Tree-From-ObjArray.

BUGS

Please report any bugs or feature requests on the bugtracker website https://github.com/perlancar/perl-Tree-From-ObjArray/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.

SEE ALSO

Role::TinyCommons::Tree::FromObjArray if you want to use this functionality via consuming a role.

Another way to create tree from a nested hash data structure: Tree::From::Struct.

Other ways to create tree: Tree::From::Text, Tree::From::TextLines, Tree::Create::Callback, Tree::Create::Size.

AUTHOR

perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2021 by perlancar@cpan.org.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.