NAME Map::Tube::Malaga - Interface to the Málaga Metro Map. SYNOPSIS use Map::Tube::Malaga; my $obj = Map::Tube::Malaga->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; DESCRIPTION It currently provides functionality to find the shortest route between the two given nodes. For more information about Málaga Map, click here . METHODS "new()" Constructor. "get_all_routes($from, $to)" [EXPERIMENTAL] Get all routes from station to station. Returns reference to array with Map::Tube::Route objects. "get_line_by_id($line_id)" Get line object defined by id. Returns Map::Tube::Line object. "get_line_by_name($line_name)" Get line object defined by name. Returns Map::Tube::Line object. "get_lines()" Get lines in metro map. Returns reference to array with Map::Tube::Line objects. "get_node_by_id($station_id)" Get station node by id. Returns Map::Tube::Node object. "get_node_by_name($station_name)" Get station node by name. Returns Map::Tube::Node object. "get_shortest_route($from, $to)" Get shortest route between $from and $to node names. Node names in $from and $to are case insensitive. Returns Map::Tube::Route object. "get_stations($line)" Get list of stations for concrete metro line. Returns reference to array with Map::Tube::Node objects. "name()" Get metro name. Returns string with metro name. "xml()" Get XML specification of Málaga metro. Returns string with XML. EXAMPLE1 # Pragmas. use strict; use warnings; # Modules. use Encode qw(encode_utf8); use Map::Tube::Malaga; # Object. my $obj = Map::Tube::Malaga->new; # Get route. my $route = $obj->get_shortest_route('Princesa-Huelin', 'Barbarela'); # Print out type. print "Route: ".encode_utf8($route)."\n"; # Output: # Route: Princesa-Huelin (Línea 2), La Isla (Línea 2), El Perchel (Línea 2), El Perchel (Línea 1), La Unión (Línea 1), Barbarela (Línea 1) EXAMPLE2 # Pragmas. use strict; use warnings; # Modules. use Map::Tube::Malaga; # Object. my $obj = Map::Tube::Malaga->new; # Get XML file. my $xml_file = $obj->xml; # Print out XML file. print "XML file: $xml_file\n"; # Output like: # XML file: .*/malaga-map.xml EXAMPLE3 # Pragmas. use strict; use warnings; # Modules. use Map::Tube::GraphViz; use Map::Tube::GraphViz::Utils qw(node_color_without_label); use Map::Tube::Malaga; # Object. my $obj = Map::Tube::Malaga->new; # GraphViz object. my $g = Map::Tube::GraphViz->new( 'callback_node' => \&node_color_without_label, 'tube' => $obj, ); # Get graph to file. $g->graph('Malaga.png'); # Print file. system "ls -l Malaga.png"; # Output like: # -rw-r--r-- 1 skim skim 51733 Sep 1 14:00 Malaga.png DEPENDENCIES File::Share, Map::Tube, Moo, namespace::clean. SEE ALSO Map::Tube Core library as Role (Moo) to process map data. Task::Map::Tube Install the Map::Tube modules. Task::Map::Tube::Metro Install the Map::Tube concrete metro modules. REPOSITORY AUTHOR Michal Špaček DEDICATION I dedicate this module to my visit in Málaga. LICENSE AND COPYRIGHT © 2015 Michal Špaček Artistic License BSD 2-Clause License VERSION 0.13