NAME
OBO::Util::Map - An implementation of a map (key -> value).
SYNOPSIS
use OBO::Util::Map;
use strict;
my $my_map = OBO::Util::Map->new();
if(!$my_map->contains_key("GO")) { print "doesn't contain key: GO"; }
if(!$my_map->contains_value("Gene Ontology")) { print "doesn't contain value: Gene Ontology"; }
if ($my_map->size() == 0) { print "empty map"; }
if ($my_map->is_empty()) { print "empty map"; }
$my_map->put("GO", "Gene Ontology");
if ($my_map->contains_key("GO")) { print "contains key: GO"; }
if ($my_map->contains_value("Gene Ontology")) { print "contains value: Gene Ontology"; }
if ($my_map->size() == 1) { print "map size is 1"; }
if (!$my_map->is_empty()) { print "map is not empty"; }
$my_map->put("CCO", "Cell Cycle Ontology");
$my_map->put("PO", "Plant Ontology");
$my_map->put("SO", "Sequence Ontology");
if ($my_map->size() == 4) { print "map size is 4"; }
if ($my_map->equals($my_map)) { print "my map is identical to itself"; }
my $my_map2 = OBO::Util::Map->new();
if (!$my_map->equals($my_map2)) { print "my map is not identical to map2"; }
if (!$my_map2->equals($my_map)) { print "map2 is not identical to my map"; }
$my_map2->put("CCO", "Cell Cycle Ontology");
$my_map2->put("PO", "Plant Ontology");
$my_map2->put("SO", "Sequence Ontology");
if (!$my_map2->equals($my_map)) { print "map2 is not identical to my map"; }
if (!$my_map->equals($my_map2)) { print "my map is not identical to map2"; }
$my_map2->put("GO", "Gene Ontology");
if ($my_map2->equals($my_map)) { print "map2 is not identical to my map"; }
if ($my_map->equals($my_map2)) { print "my map is not identical to map2"; }
if ($my_map2->get("GO") eq "Gene Ontology") { print "get GO"}
if ($my_map2->get("CCO") eq "Cell Cycle Ontology") { print "get CCO"}
if ($my_map2->get("PO") eq "Plant Ontology") { print "get PO"}
if ($my_map2->get("SO") eq "Sequence Ontology") { print "get SO"}
$my_map2->put("TO", "Trait Ontology");
if (!$my_map->equals($my_map2)) { print "my map is not identical to map2"; }
if (!$my_map2->equals($my_map)) { print "map2 is not identical to my map"; }
if ($my_map2->size() == 5) { print "map size is 5"; }
$my_map->clear();
if ($my_map->size() == 0) { print "map size is 0"; }
$my_map->put_all($my_map2);
if ($my_map->equals($my_map2)) { print "my map is identical to map2"; }
if ($my_map2->equals($my_map)) { print "map2 is identical to my map"; }
if ($my_map->size() == 5) { print "map size is 5"; }
my $UD = $my_map->remove("XO");
my $GO = $my_map->remove("GO");
if (!$my_map->contains_key("GO") && !$my_map->contains_value("Gene Ontology")) { print "GO is gone"}
print $GO; # "Gene Ontology"
if ($my_map->size() == 4) { print "map size is 4"; }
DESCRIPTION
An object that maps keys to values. A map cannot contain duplicate keys; each key can map to at most one value.
AUTHOR
Erick Antezana, <erick.antezana -@- gmail.com>
COPYRIGHT AND LICENSE
Copyright (C) 2006, 2007, 2008, 2009, 2010 by Erick Antezana
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.7 or, at your option, any later version of Perl 5 you may have available.
clear
Usage - $map->clear()
Returns - none
Args - none
Function - removes all mappings from this map
contains_key
Usage - $map->contains_key($key)
Returns - 1 (true) if this map contains a mapping for the specified key
Args - a key whose presence in this map is to be tested
Function - checks if this map contains a mapping for the specified key
contains_value
Usage - $map->contains_value($value)
Returns - 1 (true) if this map maps one or more keys to the specified value
Args - a value whose presence in this map is to be tested
Function - checks if this map maps one or more keys to the specified value
equals
Usage - $map->equals($another_map)
Returns - either 1 (true) or 0 (false)
Args - the map (Core::Util::Map) to compare with
Function - tells whether this map is equal to the given one
get
Usage - $map->get($key)
Returns - the value to which this map maps the specified key
Args - a key whose associated value is to be returned
Function - gets the value to which this map maps the specified key
is_empty
Usage - $map->is_empty()
Returns - true if this map contains no key-value mappings
Args - none
Function - checks if this map contains no key-value mappings
key_set
Usage - $map->key_set()
Returns - a set (OBO::Util::Set) view of the keys contained in this map
Args - none
Function - gets a set view of the keys contained in this map
put
Usage - $map->put("GO", "Gene Ontology")
Returns - previous value associated with specified key, or undef if there was no mapping for key
Args - a key (string) with which the specified value is to be associated and a value to be associated with the specified key.
Function - associates the specified value with the specified key in this map (optional operation)
Remark - if the map previously contained a mapping for this key, the old value is replaced by the specified value
put_all
Usage - $map->put_all($my_other_map)
Returns - none
Args - a map (OBO::Util::Map) to be stored in this map
Function - copies all of the mappings from the specified map to this map (optional operation)
Remark - the effect of this call is equivalent to that of calling put(k, v) on this map once for each mapping from key k to value v in the specified map
remove
Usage - $map->remove($key)
Returns - the previous value associated with specified key, or undef if there was no mapping for the given key
Args - a key whose mapping is to be removed from the map
Function - removes the mapping for this key from this map if it is present (optional operation)
size
Usage - $map->size()
Returns - the size of this map
Args - none
Function - tells the number of elements held by this map
values
Usage - $map->values()
Returns - a collection view of the values contained in this map
Args - none
Function - gets a collection view of the values contained in this map