NAME

FTN::Nodelist - Process FTN nodelist

SYNOPSIS

my $ndl = new FTN::Nodelist(-file => '/fido/var/ndl/nodelist.*');
if (my $node = $ndl->getNode('2:550/4077')) {
  print $node->sysop();
} else {
  warn 'Cannot find node';
}

DESCRIPTION

FTN::Nodelist contains functions that can be used to process Fidonet Technology Network nodelist and pointlist.

METHODS

new

This method creates FTN::Nodelist object. Can get following arguments:

Nodelist file path:

-file => '/path/to/nodelist'

Path can point to definite file (ex.: '/var/ndl/nodelist.357') or contain wildcard (.*) instead of digital extension. Maximum extension value will be used to find exact nodelist (ex.: '/var/ndl/nodelist.*')

Cacheable status:

-cache => 0/1

Default is 1. When cacheable status is set to 1, all search results are stored in object cache. It saves resources when searching the same address, but eats memory to store results. Choose appropriate behaviour depending on your tasks.

getNode( $addr )

Takes FTN address as argument. Address can be feed in 3D or 4D style (Zone:Net/Node, Zone:Net/Node.Point).

If 4D style is specified, point address is searching.

Returns FTN::Nodelist::Node object if node can be found in nodelist.

See FTN::Nodelist::Node for details how these results can be used.

Examples:

my $node = $ndl->getNode('2:550/0');
my $node = $ndl->getNode('2:2/0');
my $node = $ndl->getNode('2:550/4077');
my $node = $ndl->getNode('2:550/4077.101');

KNOWN ISSUES

When using wildcard in nodelist path, maximum extension is taken into account. It may bring to wrong results when there are many nodelist files and current nodelist has lesser number (for example, nodelist.365 and nodelist.006).

This issue may be resolved in next versions of FTN::Nodelist.

AUTHORS

Serguei Trouchelle <stro@railways.dp.ua> Robert James Clay <jame@rocasa.us>

LICENSE

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

COPYRIGHT

Copyright (c) 2005-2007 Serguei Trouchelle. All rights reserved. Copyright (c) 2013 Robert James Clay. All rights reserved.