Assuming you have data in given format. It would be easy to remember the parent. You don't need recursion in that case. You don't even need to mention the name of the parent. In the ouptut, you are given the order,level and parent information. Which you can format the way you like.
use strict;
use warnings;
my %Entry;
$Entry{-1} = '';
my @list;
my $id;
while(<DATA>){
chomp;
last if /OUTPUT/;
my $entry = $1 if /\b(\w+)$/;
my $level = () = $_ =~ m[\-]g;
my $item;
$Entry{$level} = $entry; #Remember the last entry
$item->{id} = ++$id;
$item->{name} = $entry;
$item->{parent} = $Entry{$level-1};
$item->{level} = $level;
push @list,$item;
}
foreach my $item (@list){
print join "|", map { $item->{$_} } qw(id level name parent);
print "\n";
}
__DATA__
foo
->bar
-->troz
->narf
__OUTPUT__
1|0|foo|
2|1|bar|foo
3|2|troz|bar
4|1|narf|foo
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.
|