198 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
		
		
			
		
	
	
			198 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
|  | /* | ||
|  |  * Copyright (C)2005-2019 Haxe Foundation | ||
|  |  * | ||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a | ||
|  |  * copy of this software and associated documentation files (the "Software"), | ||
|  |  * to deal in the Software without restriction, including without limitation | ||
|  |  * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
|  |  * and/or sell copies of the Software, and to permit persons to whom the | ||
|  |  * Software is furnished to do so, subject to the following conditions: | ||
|  |  * | ||
|  |  * The above copyright notice and this permission notice shall be included in | ||
|  |  * all copies or substantial portions of the Software. | ||
|  |  * | ||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
|  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
|  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
|  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||
|  |  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||
|  |  * DEALINGS IN THE SOFTWARE. | ||
|  |  */ | ||
|  | 
 | ||
|  | package haxe.ds; | ||
|  | 
 | ||
|  | import haxe.ds.StringMap; | ||
|  | import haxe.ds.IntMap; | ||
|  | import haxe.ds.HashMap; | ||
|  | import haxe.ds.ObjectMap; | ||
|  | import haxe.ds.WeakMap; | ||
|  | import haxe.ds.EnumValueMap; | ||
|  | import haxe.Constraints.IMap; | ||
|  | 
 | ||
|  | /** | ||
|  | 	Map allows key to value mapping for arbitrary value types, and many key | ||
|  | 	types. | ||
|  | 
 | ||
|  | 	This is a multi-type abstract, it is instantiated as one of its | ||
|  | 	specialization types depending on its type parameters. | ||
|  | 
 | ||
|  | 	A Map can be instantiated without explicit type parameters. Type inference | ||
|  | 	will then determine the type parameters from the usage. | ||
|  | 
 | ||
|  | 	Maps can also be created with `[key1 => value1, key2 => value2]` syntax. | ||
|  | 
 | ||
|  | 	Map is an abstract type, it is not available at runtime. | ||
|  | 
 | ||
|  | 	@see https://haxe.org/manual/std-Map.html | ||
|  | **/ | ||
|  | @:transitive | ||
|  | @:multiType(@:followWithAbstracts K) | ||
|  | abstract Map<K, V>(IMap<K, V>) { | ||
|  | 	/** | ||
|  | 		Creates a new Map. | ||
|  | 
 | ||
|  | 		This becomes a constructor call to one of the specialization types in | ||
|  | 		the output. The rules for that are as follows: | ||
|  | 
 | ||
|  | 		1. if `K` is a `String`, `haxe.ds.StringMap` is used | ||
|  | 		2. if `K` is an `Int`, `haxe.ds.IntMap` is used | ||
|  | 		3. if `K` is an `EnumValue`, `haxe.ds.EnumValueMap` is used | ||
|  | 		4. if `K` is any other class or structure, `haxe.ds.ObjectMap` is used | ||
|  | 		5. if `K` is any other type, it causes a compile-time error | ||
|  | 
 | ||
|  | 		(Cpp) Map does not use weak keys on `ObjectMap` by default. | ||
|  | 	**/ | ||
|  | 	public function new(); | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Maps `key` to `value`. | ||
|  | 
 | ||
|  | 		If `key` already has a mapping, the previous value disappears. | ||
|  | 
 | ||
|  | 		If `key` is `null`, the result is unspecified. | ||
|  | 	**/ | ||
|  | 	public inline function set(key:K, value:V) | ||
|  | 		this.set(key, value); | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns the current mapping of `key`. | ||
|  | 
 | ||
|  | 		If no such mapping exists, `null` is returned. | ||
|  | 
 | ||
|  | 		Note that a check like `map.get(key) == null` can hold for two reasons: | ||
|  | 
 | ||
|  | 		1. the map has no mapping for `key` | ||
|  | 		2. the map has a mapping with a value of `null` | ||
|  | 
 | ||
|  | 		If it is important to distinguish these cases, `exists()` should be | ||
|  | 		used. | ||
|  | 
 | ||
|  | 		If `key` is `null`, the result is unspecified. | ||
|  | 	**/ | ||
|  | 	@:arrayAccess public inline function get(key:K) | ||
|  | 		return this.get(key); | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns true if `key` has a mapping, false otherwise. | ||
|  | 
 | ||
|  | 		If `key` is `null`, the result is unspecified. | ||
|  | 	**/ | ||
|  | 	public inline function exists(key:K) | ||
|  | 		return this.exists(key); | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Removes the mapping of `key` and returns true if such a mapping existed, | ||
|  | 		false otherwise. | ||
|  | 
 | ||
|  | 		If `key` is `null`, the result is unspecified. | ||
|  | 	**/ | ||
|  | 	public inline function remove(key:K) | ||
|  | 		return this.remove(key); | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns an Iterator over the keys of `this` Map. | ||
|  | 
 | ||
|  | 		The order of keys is undefined. | ||
|  | 	**/ | ||
|  | 	public inline function keys():Iterator<K> { | ||
|  | 		return this.keys(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns an Iterator over the values of `this` Map. | ||
|  | 
 | ||
|  | 		The order of values is undefined. | ||
|  | 	**/ | ||
|  | 	public inline function iterator():Iterator<V> { | ||
|  | 		return this.iterator(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns an Iterator over the keys and values of `this` Map. | ||
|  | 
 | ||
|  | 		The order of values is undefined. | ||
|  | 	**/ | ||
|  | 	public inline function keyValueIterator():KeyValueIterator<K, V> { | ||
|  | 		return this.keyValueIterator(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns a shallow copy of `this` map. | ||
|  | 
 | ||
|  | 		The order of values is undefined. | ||
|  | 	**/ | ||
|  | 	public inline function copy():Map<K, V> { | ||
|  | 		return cast this.copy(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Returns a String representation of `this` Map. | ||
|  | 
 | ||
|  | 		The exact representation depends on the platform and key-type. | ||
|  | 	**/ | ||
|  | 	public inline function toString():String { | ||
|  | 		return this.toString(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 		Removes all keys from `this` Map. | ||
|  | 	**/ | ||
|  | 	public inline function clear():Void { | ||
|  | 		this.clear(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:arrayAccess @:noCompletion public inline function arrayWrite(k:K, v:V):V { | ||
|  | 		this.set(k, v); | ||
|  | 		return v; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:to static inline function toStringMap<K:String, V>(t:IMap<K, V>):StringMap<V> { | ||
|  | 		return new StringMap<V>(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:to static inline function toIntMap<K:Int, V>(t:IMap<K, V>):IntMap<V> { | ||
|  | 		return new IntMap<V>(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:to static inline function toEnumValueMapMap<K:EnumValue, V>(t:IMap<K, V>):EnumValueMap<K, V> { | ||
|  | 		return new EnumValueMap<K, V>(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:to static inline function toObjectMap<K:{}, V>(t:IMap<K, V>):ObjectMap<K, V> { | ||
|  | 		return new ObjectMap<K, V>(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:from static inline function fromStringMap<V>(map:StringMap<V>):Map<String, V> { | ||
|  | 		return cast map; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:from static inline function fromIntMap<V>(map:IntMap<V>):Map<Int, V> { | ||
|  | 		return cast map; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	@:from static inline function fromObjectMap<K:{}, V>(map:ObjectMap<K, V>):Map<K, V> { | ||
|  | 		return cast map; | ||
|  | 	} | ||
|  | } |