2023-01-22 19:55:30 -05:00
|
|
|
package funkin.util.tools;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A static extension which provides utility functions for Maps.
|
2023-06-08 16:30:45 -04:00
|
|
|
*
|
2023-01-22 19:55:30 -05:00
|
|
|
* For example, add `using MapTools` then call `map.values()`.
|
2023-06-08 16:30:45 -04:00
|
|
|
*
|
2023-01-22 19:55:30 -05:00
|
|
|
* @see https://haxe.org/manual/lf-static-extension.html
|
|
|
|
*/
|
|
|
|
class MapTools
|
|
|
|
{
|
2023-05-16 22:09:53 -04:00
|
|
|
/**
|
|
|
|
* Return the quantity of keys in the map.
|
|
|
|
*/
|
|
|
|
public static function size<K, T>(map:Map<K, T>):Int
|
|
|
|
{
|
|
|
|
return map.keys().array().length;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a list of values from the map, as an array.
|
|
|
|
*/
|
2023-01-22 19:55:30 -05:00
|
|
|
public static function values<K, T>(map:Map<K, T>):Array<T>
|
|
|
|
{
|
|
|
|
return [for (i in map.iterator()) i];
|
|
|
|
}
|
2023-04-10 16:05:37 -04:00
|
|
|
|
2023-12-14 00:47:04 -05:00
|
|
|
/**
|
|
|
|
* Create a new array with all elements of the given array, to prevent modifying the original.
|
|
|
|
*/
|
|
|
|
public static function clone<K, T>(map:Map<K, T>):Map<K, T>
|
|
|
|
{
|
|
|
|
return map.copy();
|
|
|
|
}
|
|
|
|
|
2024-04-04 03:35:36 -04:00
|
|
|
/**
|
|
|
|
* Create a new map which is a combination of the two given maps.
|
|
|
|
* @param a The base map.
|
|
|
|
* @param b The other map. The values from this take precedence.
|
|
|
|
* @return The combined map.
|
|
|
|
*/
|
|
|
|
public static function merge<K, T>(a:Map<K, T>, b:Map<K, T>):Map<K, T>
|
|
|
|
{
|
|
|
|
var result = a.copy();
|
|
|
|
|
|
|
|
for (pair in b.keyValueIterator())
|
|
|
|
{
|
|
|
|
result.set(pair.key, pair.value);
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2023-12-14 00:47:04 -05:00
|
|
|
/**
|
|
|
|
* Create a new array with clones of all elements of the given array, to prevent modifying the original.
|
|
|
|
*/
|
|
|
|
public static function deepClone<K, T, U:ICloneable<T>>(map:Map<K, U>):Map<K, T>
|
|
|
|
{
|
|
|
|
// TODO: This function does NOT work.
|
|
|
|
throw "Not implemented";
|
|
|
|
|
|
|
|
/*
|
|
|
|
var newMap:Map<K, T> = [];
|
|
|
|
// Replace each value with a clone of itself.
|
|
|
|
for (key in newMap.keys())
|
|
|
|
{
|
|
|
|
newMap.set(key, newMap.get(key).clone());
|
|
|
|
}
|
|
|
|
return newMap;
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
2023-05-16 22:09:53 -04:00
|
|
|
/**
|
|
|
|
* Return a list of keys from the map (as an array, rather than an iterator).
|
2023-08-22 04:27:30 -04:00
|
|
|
* TODO: Rename this?
|
2023-05-16 22:09:53 -04:00
|
|
|
*/
|
2023-04-10 16:05:37 -04:00
|
|
|
public static function keyValues<K, T>(map:Map<K, T>):Array<K>
|
|
|
|
{
|
2023-05-16 22:09:53 -04:00
|
|
|
return map.keys().array();
|
2023-04-10 16:05:37 -04:00
|
|
|
}
|
2023-01-22 19:55:30 -05:00
|
|
|
}
|