Port string maps to transitional syntax.
This commit is contained in:
parent
3cc5c198b4
commit
6ba4bcb955
@ -645,9 +645,28 @@ REGISTER_NATIVES(trieNatives)
|
|||||||
{"SetTrieString", SetTrieString},
|
{"SetTrieString", SetTrieString},
|
||||||
{"SetTrieValue", SetTrieValue},
|
{"SetTrieValue", SetTrieValue},
|
||||||
{"GetTrieSize", GetTrieSize},
|
{"GetTrieSize", GetTrieSize},
|
||||||
|
|
||||||
{"CreateTrieSnapshot", CreateTrieSnapshot},
|
{"CreateTrieSnapshot", CreateTrieSnapshot},
|
||||||
{"TrieSnapshotLength", TrieSnapshotLength},
|
{"TrieSnapshotLength", TrieSnapshotLength},
|
||||||
{"TrieSnapshotKeyBufferSize", TrieSnapshotKeyBufferSize},
|
{"TrieSnapshotKeyBufferSize", TrieSnapshotKeyBufferSize},
|
||||||
{"GetTrieSnapshotKey", GetTrieSnapshotKey},
|
{"GetTrieSnapshotKey", GetTrieSnapshotKey},
|
||||||
|
|
||||||
|
// Transitional syntax support.
|
||||||
|
{"StringMap.StringMap", CreateTrie},
|
||||||
|
{"StringMap.Clear", ClearTrie},
|
||||||
|
{"StringMap.GetArray", GetTrieArray},
|
||||||
|
{"StringMap.GetString", GetTrieString},
|
||||||
|
{"StringMap.GetValue", GetTrieValue},
|
||||||
|
{"StringMap.Remove", RemoveFromTrie},
|
||||||
|
{"StringMap.SetArray", SetTrieArray},
|
||||||
|
{"StringMap.SetString", SetTrieString},
|
||||||
|
{"StringMap.SetValue", SetTrieValue},
|
||||||
|
{"StringMap.Size.get", GetTrieSize},
|
||||||
|
{"StringMap.Snapshot", CreateTrieSnapshot},
|
||||||
|
|
||||||
|
{"StringMapSnapshot.Length.get", TrieSnapshotLength},
|
||||||
|
{"StringMapSnapshot.KeyBufferSize", TrieSnapshotKeyBufferSize},
|
||||||
|
{"StringMapSnapshot.GetKey", GetTrieSnapshotKey},
|
||||||
|
|
||||||
{NULL, NULL},
|
{NULL, NULL},
|
||||||
};
|
};
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/**
|
/**
|
||||||
* vim: set ts=4 sw=4 tw=99 noet :
|
* vim: set ts=4 sw=4 tw=99 noet :
|
||||||
* =============================================================================
|
* =============================================================================
|
||||||
* SourceMod (C)2004-2008 AlliedModders LLC. All rights reserved.
|
* SourceMod (C)2004-2014 AlliedModders LLC. All rights reserved.
|
||||||
* =============================================================================
|
* =============================================================================
|
||||||
*
|
*
|
||||||
* This file is part of the SourceMod/SourcePawn SDK.
|
* This file is part of the SourceMod/SourcePawn SDK.
|
||||||
@ -35,6 +35,123 @@
|
|||||||
#endif
|
#endif
|
||||||
#define _adt_trie_included
|
#define _adt_trie_included
|
||||||
|
|
||||||
|
/* Object-oriented wrapper for maps. */
|
||||||
|
methodmap StringMap < Handle
|
||||||
|
{
|
||||||
|
// Creates a hash map. A hash map is a container that can map strings (called
|
||||||
|
// "keys") to arbitrary values (cells, arrays, or strings). Keys in a hash map
|
||||||
|
// are unique. That is, there is at most one entry in the map for a given key.
|
||||||
|
//
|
||||||
|
// Insertion, deletion, and lookup in a hash map are all considered to be fast
|
||||||
|
// operations, amortized to O(1), or constant time.
|
||||||
|
//
|
||||||
|
// The word "Trie" in this API is historical. As of SourceMod 1.6, tries have
|
||||||
|
// been internally replaced with hash tables, which have O(1) insertion time
|
||||||
|
// instead of O(n).
|
||||||
|
//
|
||||||
|
// The StringMap must be freed via delete or CloseHandle().
|
||||||
|
public native StringMap();
|
||||||
|
|
||||||
|
// Sets a value in a hash map, either inserting a new entry or replacing an old one.
|
||||||
|
//
|
||||||
|
// @param key Key string.
|
||||||
|
// @param value Value to store at this key.
|
||||||
|
// @param replace If false, operation will fail if the key is already set.
|
||||||
|
// @return True on success, false on failure.
|
||||||
|
public native bool SetValue(const char[] key, any value, bool replace=true);
|
||||||
|
|
||||||
|
// Sets an array value in a Map, either inserting a new entry or replacing an old one.
|
||||||
|
//
|
||||||
|
// @param key Key string.
|
||||||
|
// @param array Array to store.
|
||||||
|
// @param num_items Number of items in the array.
|
||||||
|
// @param replace If false, operation will fail if the key is already set.
|
||||||
|
// @return True on success, false on failure.
|
||||||
|
public native bool SetArray(const char[] key, const any[] array, int num_items, bool replace=true);
|
||||||
|
|
||||||
|
// Sets a string value in a Map, either inserting a new entry or replacing an old one.
|
||||||
|
//
|
||||||
|
// @param key Key string.
|
||||||
|
// @param value String to store.
|
||||||
|
// @param replace If false, operation will fail if the key is already set.
|
||||||
|
// @return True on success, false on failure.
|
||||||
|
public native bool SetString(const char[] key, const char[] value, bool replace=true);
|
||||||
|
|
||||||
|
// Retrieves a value in a Map.
|
||||||
|
//
|
||||||
|
// @param key Key string.
|
||||||
|
// @param value Variable to store value.
|
||||||
|
// @return True on success. False if the key is not set, or the key is set
|
||||||
|
// as an array or string (not a value).
|
||||||
|
public native bool GetValue(const char[] key, any &value);
|
||||||
|
|
||||||
|
// Retrieves an array in a Map.
|
||||||
|
//
|
||||||
|
// @param map Map Handle.
|
||||||
|
// @param key Key string.
|
||||||
|
// @param array Buffer to store array.
|
||||||
|
// @param max_size Maximum size of array buffer.
|
||||||
|
// @param size Optional parameter to store the number of elements written to the buffer.
|
||||||
|
// @return True on success. False if the key is not set, or the key is set
|
||||||
|
// as a value or string (not an array).
|
||||||
|
public native bool GetArray(const char[] key, any[] array, int max_size, int &size=0);
|
||||||
|
|
||||||
|
// Retrieves a string in a Map.
|
||||||
|
//
|
||||||
|
// @param key Key string.
|
||||||
|
// @param value Buffer to store value.
|
||||||
|
// @param max_size Maximum size of string buffer.
|
||||||
|
// @param size Optional parameter to store the number of bytes written to the buffer.
|
||||||
|
// @return True on success. False if the key is not set, or the key is set
|
||||||
|
// as a value or array (not a string).
|
||||||
|
public native bool GetString(const char[] key, char[] value, int max_size, int &size=0);
|
||||||
|
|
||||||
|
// Removes a key entry from a Map.
|
||||||
|
//
|
||||||
|
// @param key Key string.
|
||||||
|
// @return True on success, false if the value was never set.
|
||||||
|
public native bool Remove(const char[] key);
|
||||||
|
|
||||||
|
// Clears all entries from a Map.
|
||||||
|
public native void Clear();
|
||||||
|
|
||||||
|
// Create a snapshot of the map's keys. See StringMapSnapshot.
|
||||||
|
public native StringMapSnapshot Snapshot();
|
||||||
|
|
||||||
|
// Retrieves the number of elements in a map.
|
||||||
|
property int Size {
|
||||||
|
public native get();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// A StringMapSnapshot is created via StringMap.Snapshot(). It captures the
|
||||||
|
// keys on a map so they can be read. Snapshots must be freed with delete or
|
||||||
|
// CloseHandle().
|
||||||
|
methodmap StringMapSnapshot < Handle
|
||||||
|
{
|
||||||
|
// Returns the number of keys in the map snapshot.
|
||||||
|
property int Length {
|
||||||
|
public native get();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns the buffer size required to store a given key. That is, it
|
||||||
|
// returns the length of the key plus one.
|
||||||
|
//
|
||||||
|
// @param index Key index (starting from 0).
|
||||||
|
// @return Buffer size required to store the key string.
|
||||||
|
// @error Index out of range.
|
||||||
|
public native int KeyBufferSize(int index);
|
||||||
|
|
||||||
|
// Retrieves the key string of a given key in a map snapshot.
|
||||||
|
//
|
||||||
|
// @param index Key index (starting from 0).
|
||||||
|
// @param buffer String buffer.
|
||||||
|
// @param maxlength Maximum buffer length.
|
||||||
|
// @return Number of bytes written to the buffer.
|
||||||
|
// @error Index out of range.
|
||||||
|
public native int GetKey(int index, char[] buffer, int maxlength);
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a hash map. A hash map is a container that can map strings (called
|
* Creates a hash map. A hash map is a container that can map strings (called
|
||||||
* "keys") to arbitrary values (cells, arrays, or strings). Keys in a hash map
|
* "keys") to arbitrary values (cells, arrays, or strings). Keys in a hash map
|
||||||
@ -61,7 +178,7 @@ native StringMap:CreateTrie();
|
|||||||
* @return True on success, false on failure.
|
* @return True on success, false on failure.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native bool:SetTrieValue(Handle:map, const String:key[], any:value, bool:replace=true);
|
native bool SetTrieValue(Handle map, const char[] key, any value, bool replace=true);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets an array value in a Map, either inserting a new entry or replacing an old one.
|
* Sets an array value in a Map, either inserting a new entry or replacing an old one.
|
||||||
@ -74,7 +191,7 @@ native bool:SetTrieValue(Handle:map, const String:key[], any:value, bool:replace
|
|||||||
* @return True on success, false on failure.
|
* @return True on success, false on failure.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native bool:SetTrieArray(Handle:map, const String:key[], const any:array[], num_items, bool:replace=true);
|
native bool SetTrieArray(Handle map, const char[] key, const any[] array, int num_items, bool replace=true);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets a string value in a Map, either inserting a new entry or replacing an old one.
|
* Sets a string value in a Map, either inserting a new entry or replacing an old one.
|
||||||
@ -86,7 +203,7 @@ native bool:SetTrieArray(Handle:map, const String:key[], const any:array[], num_
|
|||||||
* @return True on success, false on failure.
|
* @return True on success, false on failure.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native bool:SetTrieString(Handle:map, const String:key[], const String:value[], bool:replace=true);
|
native bool SetTrieString(Handle map, const char[] key, const char[] value, bool replace=true);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves a value in a Map.
|
* Retrieves a value in a Map.
|
||||||
@ -98,7 +215,7 @@ native bool:SetTrieString(Handle:map, const String:key[], const String:value[],
|
|||||||
* as an array or string (not a value).
|
* as an array or string (not a value).
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native bool:GetTrieValue(Handle:map, const String:key[], &any:value);
|
native bool GetTrieValue(Handle map, const char[] key, any &value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves an array in a Map.
|
* Retrieves an array in a Map.
|
||||||
@ -112,7 +229,7 @@ native bool:GetTrieValue(Handle:map, const String:key[], &any:value);
|
|||||||
* as a value or string (not an array).
|
* as a value or string (not an array).
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native bool:GetTrieArray(Handle:map, const String:key[], any:array[], max_size, &size=0);
|
native bool GetTrieArray(Handle map, const char[] key, any[] array, int max_size, int &size=0);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves a string in a Map.
|
* Retrieves a string in a Map.
|
||||||
@ -126,7 +243,7 @@ native bool:GetTrieArray(Handle:map, const String:key[], any:array[], max_size,
|
|||||||
* as a value or array (not a string).
|
* as a value or array (not a string).
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native bool:GetTrieString(Handle:map, const String:key[], String:value[], max_size, &size=0);
|
native bool GetTrieString(Handle map, const char[] key, char[] value, int max_size, int &size=0);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes a key entry from a Map.
|
* Removes a key entry from a Map.
|
||||||
@ -136,7 +253,7 @@ native bool:GetTrieString(Handle:map, const String:key[], String:value[], max_si
|
|||||||
* @return True on success, false if the value was never set.
|
* @return True on success, false if the value was never set.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native RemoveFromTrie(Handle:map, const String:key[]);
|
native RemoveFromTrie(Handle map, const char[] key);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clears all entries from a Map.
|
* Clears all entries from a Map.
|
||||||
@ -144,7 +261,7 @@ native RemoveFromTrie(Handle:map, const String:key[]);
|
|||||||
* @param map Map Handle.
|
* @param map Map Handle.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native ClearTrie(Handle:map);
|
native ClearTrie(Handle map);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves the number of elements in a map.
|
* Retrieves the number of elements in a map.
|
||||||
@ -153,23 +270,7 @@ native ClearTrie(Handle:map);
|
|||||||
* @return Number of elements in the trie.
|
* @return Number of elements in the trie.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native GetTrieSize(Handle:map);
|
native GetTrieSize(Handle map);
|
||||||
|
|
||||||
/* Object-oriented wrapper for maps. */
|
|
||||||
methodmap StringMap < Handle {
|
|
||||||
public StringMap() = CreateTrie;
|
|
||||||
public SetValue() = SetTrieValue;
|
|
||||||
public SetArray() = SetTrieArray;
|
|
||||||
public SetString() = SetTrieString;
|
|
||||||
public GetValue() = GetTrieValue;
|
|
||||||
public GetArray() = GetTrieArray;
|
|
||||||
public GetString() = GetTrieString;
|
|
||||||
public Remove() = RemoveFromTrie;
|
|
||||||
public Clear() = ClearTrie;
|
|
||||||
property int Size {
|
|
||||||
public get() = GetTrieSize;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a snapshot of all keys in the map. If the map is changed after this
|
* Creates a snapshot of all keys in the map. If the map is changed after this
|
||||||
@ -179,7 +280,7 @@ methodmap StringMap < Handle {
|
|||||||
* @return New Map Snapshot Handle, which must be closed via CloseHandle().
|
* @return New Map Snapshot Handle, which must be closed via CloseHandle().
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native Handle:CreateTrieSnapshot(Handle:map);
|
native Handle CreateTrieSnapshot(Handle map);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the number of keys in a map snapshot. Note that this may be
|
* Returns the number of keys in a map snapshot. Note that this may be
|
||||||
@ -190,7 +291,7 @@ native Handle:CreateTrieSnapshot(Handle:map);
|
|||||||
* @return Number of keys.
|
* @return Number of keys.
|
||||||
* @error Invalid Handle.
|
* @error Invalid Handle.
|
||||||
*/
|
*/
|
||||||
native TrieSnapshotLength(Handle:snapshot);
|
native TrieSnapshotLength(Handle snapshot);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the buffer size required to store a given key. That is, it returns
|
* Returns the buffer size required to store a given key. That is, it returns
|
||||||
@ -201,7 +302,7 @@ native TrieSnapshotLength(Handle:snapshot);
|
|||||||
* @return Buffer size required to store the key string.
|
* @return Buffer size required to store the key string.
|
||||||
* @error Invalid Handle or index out of range.
|
* @error Invalid Handle or index out of range.
|
||||||
*/
|
*/
|
||||||
native TrieSnapshotKeyBufferSize(Handle:snapshot, index);
|
native TrieSnapshotKeyBufferSize(Handle snapshot, int index);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves the key string of a given key in a map snapshot.
|
* Retrieves the key string of a given key in a map snapshot.
|
||||||
@ -213,4 +314,4 @@ native TrieSnapshotKeyBufferSize(Handle:snapshot, index);
|
|||||||
* @return Number of bytes written to the buffer.
|
* @return Number of bytes written to the buffer.
|
||||||
* @error Invalid Handle or index out of range.
|
* @error Invalid Handle or index out of range.
|
||||||
*/
|
*/
|
||||||
native GetTrieSnapshotKey(Handle:snapshot, index, String:buffer[], maxlength);
|
native GetTrieSnapshotKey(Handle snapshot, int index, char[] buffer, int maxlength);
|
||||||
|
@ -17,10 +17,10 @@ public OnPluginStart()
|
|||||||
|
|
||||||
public Action:RunTests(argc)
|
public Action:RunTests(argc)
|
||||||
{
|
{
|
||||||
new StringMap:map = StringMap();
|
StringMap map = StringMap();
|
||||||
|
|
||||||
for (new i = 0; i < 64; i++) {
|
for (new i = 0; i < 64; i++) {
|
||||||
new String:buffer[24];
|
char buffer[24];
|
||||||
Format(buffer, sizeof(buffer), "%d", i);
|
Format(buffer, sizeof(buffer), "%d", i);
|
||||||
|
|
||||||
if (!map.SetValue(buffer, i))
|
if (!map.SetValue(buffer, i))
|
||||||
@ -35,11 +35,11 @@ public Action:RunTests(argc)
|
|||||||
|
|
||||||
// Setting 17 without replace should fail.
|
// Setting 17 without replace should fail.
|
||||||
new value;
|
new value;
|
||||||
if (SetTrieValue(map, "17", 999, false))
|
if (map.SetValue("17", 999, false))
|
||||||
ThrowError("set map 17 should fail");
|
ThrowError("set map 17 should fail");
|
||||||
if (!map.GetValue("17", value) || value != 17)
|
if (!map.GetValue("17", value) || value != 17)
|
||||||
ThrowError("value at 17 not correct");
|
ThrowError("value at 17 not correct");
|
||||||
if (!SetTrieValue(map, "17", 999))
|
if (!map.SetValue("17", 999))
|
||||||
ThrowError("set map 17 = 999 should succeed");
|
ThrowError("set map 17 = 999 should succeed");
|
||||||
if (!map.GetValue("17", value) || value != 999)
|
if (!map.GetValue("17", value) || value != 999)
|
||||||
ThrowError("value at 17 not correct");
|
ThrowError("value at 17 not correct");
|
||||||
@ -49,8 +49,8 @@ public Action:RunTests(argc)
|
|||||||
ThrowError("map size not 64");
|
ThrowError("map size not 64");
|
||||||
|
|
||||||
// Check "cat" is not found.
|
// Check "cat" is not found.
|
||||||
new array[64];
|
int array[64];
|
||||||
new String:string[64];
|
char string[64];
|
||||||
if (map.GetValue("cat", value) ||
|
if (map.GetValue("cat", value) ||
|
||||||
map.GetArray("cat", array, sizeof(array)) ||
|
map.GetArray("cat", array, sizeof(array)) ||
|
||||||
map.GetString("cat", string, sizeof(string)))
|
map.GetString("cat", string, sizeof(string)))
|
||||||
@ -129,16 +129,16 @@ public Action:RunTests(argc)
|
|||||||
map.SetString("butterflies", "bees");
|
map.SetString("butterflies", "bees");
|
||||||
map.SetString("egg", "egg");
|
map.SetString("egg", "egg");
|
||||||
|
|
||||||
new Handle:keys = CreateTrieSnapshot(map);
|
StringMapSnapshot keys = map.Snapshot();
|
||||||
{
|
{
|
||||||
if (TrieSnapshotLength(keys) != 3)
|
if (keys.Length != 3)
|
||||||
ThrowError("map snapshot length should be 3");
|
ThrowError("map snapshot length should be 3");
|
||||||
|
|
||||||
new bool:found[3];
|
bool found[3];
|
||||||
for (new i = 0; i < TrieSnapshotLength(keys); i++) {
|
for (new i = 0; i < keys.Length; i++) {
|
||||||
new size = TrieSnapshotKeyBufferSize(keys, i);
|
new size = keys.KeyBufferSize(i);
|
||||||
new String:buffer[size];
|
char[] buffer = new char[size];
|
||||||
GetTrieSnapshotKey(keys, i, buffer, size);
|
keys.GetKey(i, buffer, size);
|
||||||
|
|
||||||
if (strcmp(buffer, "adventure") == 0)
|
if (strcmp(buffer, "adventure") == 0)
|
||||||
found[0] = true;
|
found[0] = true;
|
||||||
|
Loading…
Reference in New Issue
Block a user