package Map::Tube::Yekaterinburg; # Pragmas. use strict; use warnings; use 5.006; # Modules. use File::Share ':all'; use Moo; use namespace::clean; # Version. our $VERSION = 0.05; # Get XML. has xml => ( 'is' => 'ro', 'default' => sub { return dist_file('Map-Tube-Yekaterinburg', 'yekaterinburg-map.xml'); }, ); with 'Map::Tube'; 1; __END__ =encoding utf8 =head1 NAME Map::Tube::Yekaterinburg - Interface to the Yekaterinburg Metro Map. =head1 SYNOPSIS use Map::Tube::Yekaterinburg; my $obj = Map::Tube::Yekaterinburg->new; my $routes_ar = $obj->get_all_routes($from, $to); my $line = $obj->get_line_by_id($line_id); my $line = $obj->get_line_by_name($line_name); my $lines_ar = $obj->get_lines; my $station = $obj->get_node_by_id($station_id); my $station = $obj->get_node_by_name($station_name); my $route = $obj->get_shortest_route($from, $to); my $stations_ar = $obj->get_stations($line); my $metro_name = $obj->name; my $xml_file = $obj->xml; =head1 DESCRIPTION It currently provides functionality to find the shortest route between the two given nodes. For more information about Yekaterinburg Map, click L. =head1 METHODS =over 8 =item C Constructor. =item C [EXPERIMENTAL] Get all routes from station to station. Returns reference to array with Map::Tube::Route objects. =item C [EXPERIMENTAL] Get all routes from station to station. Returns reference to array with Map::Tube::Route objects. =item C Get line object defined by id. Returns Map::Tube::Line object. =item C Get lines in metro map. Returns reference to unsorted array with Map::Tube::Line objects. =item C Get station node by id. Returns Map::Tube::Node object. =item C Get station node by name. Returns Map::Tube::Node object. =item C Get shortest route between $from and $to node names. Node names in $from and $to are case insensitive. Returns Map::Tube::Route object. =item C Get list of stations for concrete metro line. Returns reference to array with Map::Tube::Node objects. =item C Get metro name. Returns string with metro name. =item C Get XML specification of Yekaterinburg metro. Returns string with XML. =back =head1 EXAMPLE1 # Pragmas. use strict; use warnings; # Modules. use Encode qw(decode_utf8 encode_utf8); use Map::Tube::Yekaterinburg; # Object. my $obj = Map::Tube::Yekaterinburg->new; # Get route. my $route = $obj->get_shortest_route(decode_utf8('Геологическая'), decode_utf8('Уралмаш')); # Print out type. print "Route: ".encode_utf8($route)."\n"; # Output: # Route: Геологическая (Первая линия), Площадь 1905 года (Первая линия), Динамо (Первая линия), Уральская (Первая линия), Машиностроителей (Первая линия), Уралмаш (Первая линия) =head1 EXAMPLE2 # Pragmas. use strict; use warnings; # Modules. use Map::Tube::Yekaterinburg; # Object. my $obj = Map::Tube::Yekaterinburg->new; # Get XML file. my $xml_file = $obj->xml; # Print out XML file. print "XML file: $xml_file\n"; # Output like: # XML file: .*/yekaterinburg-map.xml =head1 EXAMPLE3 # Pragmas. use strict; use warnings; # Modules. use Map::Tube::GraphViz; use Map::Tube::GraphViz::Utils qw(node_color_without_label); use Map::Tube::Yekaterinburg; # Object. my $obj = Map::Tube::Yekaterinburg->new; # GraphViz object. my $g = Map::Tube::GraphViz->new( 'callback_node' => \&node_color_without_label, 'tube' => $obj, ); # Get graph to file. $g->graph('Yekaterinburg.png'); # Print file. system "ls -l Yekaterinburg.png"; # Output like: # -rw-r--r-- 1 skim skim 28866 Feb 17 20:42 Yekaterinburg.png =begin html Екатеринбургский метрополитен =end html =head1 EXAMPLE4 # Pragmas. use strict; use warnings; # Modules. use Encode qw(encode_utf8); use Map::Tube::Yekaterinburg; # Object. my $obj = Map::Tube::Yekaterinburg->new; # Get lines. my $lines_ar = $obj->get_lines; # Print out. map { print encode_utf8($_->name)."\n"; } sort @{$lines_ar}; # Output: # Первая линия =head1 DEPENDENCIES L, L, L, L. =head1 SEE ALSO =over =item L Core library as Role (Moo) to process map data. =item L Install the Map::Tube modules. =item L Install the Map::Tube concrete metro modules. =back =head1 REPOSITORY L =head1 AUTHOR Michal Špaček L L =head1 LICENSE AND COPYRIGHT © 2014-2015 Michal Špaček Artistic License BSD 2-Clause License =head1 VERSION 0.05 =cut