2015-03-05 16:47:32 +00:00
/ *
2015-03-06 16:10:34 +00:00
Copyright ( c ) 2015 , Emir Pasic
All rights reserved .
2015-03-05 16:47:32 +00:00
2015-03-06 16:10:34 +00:00
Redistribution and use in source and binary forms , with or without
modification , are permitted provided that the following conditions are met :
2015-03-05 16:47:32 +00:00
2015-03-06 16:10:34 +00:00
* Redistributions of source code must retain the above copyright notice , this
list of conditions and the following disclaimer .
2015-03-05 16:47:32 +00:00
2015-03-06 16:10:34 +00:00
* Redistributions in binary form must reproduce the above copyright notice ,
this list of conditions and the following disclaimer in the documentation
and / or other materials provided with the distribution .
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY ,
OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
2015-03-05 16:47:32 +00:00
* /
2016-06-25 15:02:21 +00:00
// Package maps provides abstract Map interface for that all concrete maps should implement.
//
// In computer science, an associative array, map, symbol table, or dictionary is an abstract data type composed of a collection of (key, value) pairs, such that each possible key appears just once in the collection.
//
// Operations associated with this data type allow:
// - the addition of a pair to the collection
// - the removal of a pair from the collection
// - the modification of an existing pair
// - the lookup of a value associated with a particular key
//
// Reference: https://en.wikipedia.org/wiki/Associative_array
2015-03-05 16:47:32 +00:00
package maps
2015-03-07 18:23:43 +00:00
import "github.com/emirpasic/gods/containers"
2016-06-24 19:52:16 +00:00
// Map interface that all maps implement
2016-06-22 01:09:48 +00:00
type Map interface {
2015-03-05 16:47:32 +00:00
Put ( key interface { } , value interface { } )
Get ( key interface { } ) ( value interface { } , found bool )
Remove ( key interface { } )
Keys ( ) [ ] interface { }
2015-03-07 18:23:43 +00:00
2016-06-22 01:09:48 +00:00
containers . Container
2015-03-07 18:23:43 +00:00
// Empty() bool
// Size() int
// Clear()
// Values() []interface{}
2015-03-05 16:47:32 +00:00
}