2008-10-04 22:59:11 +02:00
|
|
|
/**
|
2015-03-21 15:43:24 +01:00
|
|
|
* vim: set ts=4 sw=4 tw=99 noet :
|
2008-10-04 22:59:11 +02:00
|
|
|
* =============================================================================
|
2015-03-21 15:43:24 +01:00
|
|
|
* SourceMod (C)2004-2014 AlliedModders LLC. All rights reserved.
|
2008-10-04 22:59:11 +02:00
|
|
|
* =============================================================================
|
|
|
|
*
|
|
|
|
* This file is part of the SourceMod/SourcePawn SDK.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU General Public License, version 3.0, as published by the
|
|
|
|
* Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
|
* details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* As a special exception, AlliedModders LLC gives you permission to link the
|
|
|
|
* code of this program (as well as its derivative works) to "Half-Life 2," the
|
|
|
|
* "Source Engine," the "SourcePawn JIT," and any Game MODs that run on software
|
|
|
|
* by the Valve Corporation. You must obey the GNU General Public License in
|
|
|
|
* all respects for all other code used. Additionally, AlliedModders LLC grants
|
|
|
|
* this exception to all derivative works. AlliedModders LLC defines further
|
|
|
|
* exceptions, found in LICENSE.txt (as of this writing, version JULY-31-2007),
|
|
|
|
* or <http://www.sourcemod.net/license.php>.
|
|
|
|
*
|
2009-04-14 23:40:48 +02:00
|
|
|
* Version: $Id$
|
2008-10-04 22:59:11 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#if defined _keyvalues_included
|
|
|
|
#endinput
|
|
|
|
#endif
|
|
|
|
#define _keyvalues_included
|
|
|
|
|
|
|
|
/**
|
|
|
|
* KeyValue data value types
|
|
|
|
*/
|
|
|
|
enum KvDataTypes
|
|
|
|
{
|
|
|
|
KvData_None = 0, /**< Type could not be identified, or no type */
|
|
|
|
KvData_String, /**< String value */
|
|
|
|
KvData_Int, /**< Integer value */
|
|
|
|
KvData_Float, /**< Floating point value */
|
|
|
|
KvData_Ptr, /**< Pointer value (sometimes called "long") */
|
|
|
|
KvData_WString, /**< Wide string value */
|
|
|
|
KvData_Color, /**< Color value */
|
|
|
|
KvData_UInt64, /**< Large integer value */
|
|
|
|
/* --- */
|
|
|
|
KvData_NUMTYPES,
|
|
|
|
};
|
|
|
|
|
2015-03-21 15:43:24 +01:00
|
|
|
methodmap KeyValues < Handle
|
|
|
|
{
|
|
|
|
// Creates a new KeyValues structure. The Handle must be closed with
|
|
|
|
// CloseHandle() or delete.
|
|
|
|
//
|
|
|
|
// @param name Name of the root section.
|
|
|
|
// @param firstKey If non-empty, specifies the first key value.
|
|
|
|
// @param firstValue If firstKey is non-empty, specifies the first key's value.
|
|
|
|
public native KeyValues(const char[] name, const char[] firstKey="", const char[] firstValue="");
|
|
|
|
|
|
|
|
// Exports a KeyValues tree to a file. The tree is dumped from the current position.
|
|
|
|
//
|
|
|
|
// @param file File to dump write to.
|
|
|
|
// @return True on success, false otherwise.
|
|
|
|
public native bool ExportToFile(const char[] file);
|
|
|
|
|
|
|
|
// Imports a file in KeyValues format. The file is read into the current
|
|
|
|
// position of the tree.
|
|
|
|
//
|
|
|
|
// @param file File to read from.
|
|
|
|
// @return True on success, false otherwise.
|
|
|
|
public native bool ImportFromFile(const char[] file);
|
|
|
|
|
|
|
|
// Converts a given string to a KeyValues tree. The string is read into
|
|
|
|
// the current postion of the tree.
|
|
|
|
//
|
|
|
|
// @param buffer String buffer to load into the KeyValues.
|
|
|
|
// @param resourceName The resource name of the KeyValues, used for error tracking purposes.
|
|
|
|
// @return True on success, false otherwise.
|
|
|
|
public native bool ImportFromString(const char[] buffer, const char[] resourceName="StringToKeyValues");
|
|
|
|
|
|
|
|
// Imports subkeys in the given KeyValues, at the current position in that
|
|
|
|
// KeyValues, into the current position in this KeyValues. Note that this
|
|
|
|
// copies keys; it does not embed a reference to them.
|
|
|
|
//
|
|
|
|
// @param other Origin KeyValues Handle.
|
|
|
|
public native void Import(KeyValues other);
|
|
|
|
|
|
|
|
// Sets a string value of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param kv KeyValues Handle.
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param value String value.
|
|
|
|
public native void SetString(const char[] key, const char[] value);
|
|
|
|
|
|
|
|
// Sets an integer value of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param value Value number.
|
|
|
|
public native void SetNum(const char[] key, int value);
|
|
|
|
|
|
|
|
// Sets a large integer value of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param value Large integer value (0=High bits, 1=Low bits)
|
|
|
|
public native void SetUInt64(const char[] key, const value[2]);
|
|
|
|
|
|
|
|
// Sets a floating point value of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param value Floating point value.
|
|
|
|
public native void SetFloat(const char[] key, float value);
|
|
|
|
|
|
|
|
// Sets a set of color values of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param r Red value.
|
|
|
|
// @param g Green value.
|
|
|
|
// @param b Blue value.
|
|
|
|
// @param a Alpha value.
|
|
|
|
public native void SetColor(const char[] key, int r, int g, int b, int a=0);
|
|
|
|
|
|
|
|
// Sets a set of color values of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param color Red, green, blue and alpha channels.
|
|
|
|
public void SetColor4(const char[] key, const int color[4]) {
|
|
|
|
this.SetColor(key, color[0], color[1], color[2], color[3]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Sets a vector value of a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param vec Vector value.
|
|
|
|
public native void SetVector(const char[] key, const float vec[3]);
|
|
|
|
|
|
|
|
// Retrieves a string value from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param value Buffer to store key value in.
|
|
|
|
// @param maxlength Maximum length of the value buffer.
|
|
|
|
// @param defvalue Optional default value to use if the key is not found.
|
|
|
|
public native void GetString(const char[] key, char[] value, int maxlength, const char[] defvalue="");
|
|
|
|
|
|
|
|
// Retrieves an integer value from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param defvalue Optional default value to use if the key is not found.
|
|
|
|
// @return Integer value of the key.
|
|
|
|
public native int GetNum(const char[] key, int defvalue=0);
|
|
|
|
|
|
|
|
// Retrieves a floating point value from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param defvalue Optional default value to use if the key is not found.
|
|
|
|
// @return Floating point value of the key.
|
|
|
|
public native float GetFloat(const char[] key, float defvalue=0.0);
|
|
|
|
|
|
|
|
// Retrieves a set of color values from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param r Red value, set by reference.
|
|
|
|
// @param g Green value, set by reference.
|
|
|
|
// @param b Blue value, set by reference.
|
|
|
|
// @param a Alpha value, set by reference.
|
|
|
|
public native void GetColor(const char[] key, &r, &g, &b, &a);
|
|
|
|
|
|
|
|
// Retrives a set of color values from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param color Red, green, blue, and alpha channels.
|
|
|
|
public void GetColor4(const char[] key, int color[4]) {
|
|
|
|
int r, g, b, a;
|
|
|
|
this.GetColor(key, r, g, b, a);
|
|
|
|
color[0] = r;
|
|
|
|
color[1] = g;
|
|
|
|
color[2] = b;
|
|
|
|
color[3] = a;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Retrieves a large integer value from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param value Array to represent the large integer.
|
|
|
|
// @param defvalue Optional default value to use if the key is not found.
|
|
|
|
public native void GetUInt64(const char[] key, int value[2], int defvalue[2]={0,0});
|
|
|
|
|
|
|
|
// Retrieves a vector value from a KeyValues key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key, or NULL_STRING.
|
|
|
|
// @param vec Destination vector to store the value in.
|
|
|
|
// @param defvalue Optional default value to use if the key is not found.
|
|
|
|
public native void GetVector(const char[] key, float vec[3], const float defvalue[3]={0.0, 0.0, 0.0});
|
|
|
|
|
|
|
|
// Sets the current position in the KeyValues tree to the given key.
|
|
|
|
//
|
|
|
|
// @param key Name of the key.
|
|
|
|
// @param create If true, and the key does not exist, it will be created.
|
|
|
|
// @return True if the key exists, false if it does not and was not created.
|
|
|
|
public native bool JumpToKey(const char[] key, bool create=false);
|
|
|
|
|
|
|
|
// Sets the current position in the KeyValues tree to the given key.
|
|
|
|
//
|
|
|
|
// @param id KeyValues id.
|
|
|
|
// @return True if the key exists, false if it does not.
|
|
|
|
public native bool JumpToKeySymbol(int id);
|
|
|
|
|
|
|
|
// Sets the current position in the KeyValues tree to the first sub key.
|
|
|
|
// This native adds to the internal traversal stack.
|
|
|
|
//
|
|
|
|
// @param keyOnly If false, non-keys will be traversed (values).
|
|
|
|
// @return True on success, false if there was no first sub key.
|
|
|
|
public native bool GotoFirstSubKey(bool keyOnly=true);
|
|
|
|
|
|
|
|
// Sets the current position in the KeyValues tree to the next sub key.
|
|
|
|
// This native does NOT add to the internal traversal stack, and thus
|
|
|
|
// GoBack() is not needed for each successive call to this function.
|
|
|
|
//
|
|
|
|
// @param keyOnly If false, non-keys will be traversed (values).
|
|
|
|
// @return True on success, false if there was no next sub key.
|
|
|
|
public native bool GotoNextKey(bool keyOnly=true);
|
|
|
|
|
|
|
|
// Saves the current position in the traversal stack onto the traversal
|
|
|
|
// stack. This can be useful if you wish to use KvGotoNextKey() and
|
|
|
|
// have the previous key saved for backwards traversal.
|
|
|
|
//
|
|
|
|
// @param kv KeyValues Handle.
|
|
|
|
public native void SavePosition();
|
|
|
|
|
|
|
|
// Jumps back to the previous position. Returns false if there are no
|
|
|
|
// previous positions (i.e., at the root node). This should be called
|
|
|
|
// once for each successful Jump call, in order to return to the top node.
|
|
|
|
// This function pops one node off the internal traversal stack.
|
|
|
|
//
|
|
|
|
// @return True on success, false if there is no higher node.
|
|
|
|
public native bool GoBack();
|
|
|
|
|
|
|
|
// Removes the given key from the current position.
|
|
|
|
//
|
|
|
|
// @param key Name of the key.
|
|
|
|
// @return True on success, false if key did not exist.
|
|
|
|
public native bool DeleteKey(const char[] key);
|
|
|
|
|
|
|
|
// Removes the current sub-key and attempts to set the position
|
|
|
|
// to the sub-key after the removed one. If no such sub-key exists,
|
|
|
|
// the position will be the parent key in the traversal stack.
|
|
|
|
// Given the sub-key having position "N" in the traversal stack, the
|
|
|
|
// removal will always take place from position "N-1."
|
|
|
|
//
|
|
|
|
// @param kv KeyValues Handle.
|
|
|
|
// @return 1 if removal succeeded and there was another key.
|
|
|
|
// 0 if the current node was not contained in the
|
|
|
|
// previous node, or no previous node exists.
|
|
|
|
// -1 if removal succeeded and there were no more keys,
|
|
|
|
// thus the state is as if KvGoBack() was called.
|
|
|
|
public native int DeleteThis();
|
|
|
|
|
|
|
|
// Sets the position back to the top node, emptying the entire node
|
|
|
|
// traversal history. This can be used instead of looping KvGoBack()
|
|
|
|
// if recursive iteration is not important.
|
|
|
|
//
|
|
|
|
// @param kv KeyValues Handle.
|
|
|
|
public native void Rewind();
|
|
|
|
|
|
|
|
// Retrieves the current section name.
|
|
|
|
//
|
|
|
|
// @param section Buffer to store the section name.
|
|
|
|
// @param maxlength Maximum length of the name buffer.
|
|
|
|
// @return True on success, false on failure.
|
|
|
|
public native bool GetSectionName(char[] section, int maxlength);
|
|
|
|
|
|
|
|
// Sets the current section name.
|
|
|
|
//
|
|
|
|
// @param section Section name.
|
|
|
|
public native void SetSectionName(const char[] section);
|
|
|
|
|
|
|
|
// Returns the data type at a key.
|
|
|
|
//
|
|
|
|
// @param key Key name.
|
|
|
|
// @return KvDataType value of the key.
|
|
|
|
public native KvDataTypes GetDataType(const char[] key);
|
|
|
|
|
|
|
|
// Sets whether or not the KeyValues parser will read escape sequences.
|
|
|
|
// For example, \n would be read as a literal newline. This defaults
|
|
|
|
// to false for new KeyValues structures.
|
|
|
|
//
|
|
|
|
// @param useEscapes Whether or not to read escape sequences.
|
|
|
|
public native void SetEscapeSequences(bool useEscapes);
|
|
|
|
|
|
|
|
// Returns the position in the jump stack; I.e. the number of calls
|
|
|
|
// required for KvGoBack to return to the root node. If at the root node,
|
|
|
|
// 0 is returned.
|
|
|
|
//
|
|
|
|
// @return Number of non-root nodes in the jump stack.
|
|
|
|
public native int NodesInStack();
|
|
|
|
|
|
|
|
// Finds a KeyValues name by id.
|
|
|
|
//
|
|
|
|
// @param id KeyValues id.
|
|
|
|
// @param name Buffer to store the name.
|
|
|
|
// @param maxlength Maximum length of the value buffer.
|
|
|
|
// @return True on success, false if id not found.
|
|
|
|
public native bool FindKeyById(int id, char[] name, int maxlength);
|
|
|
|
|
|
|
|
// Finds a KeyValues id inside a KeyValues tree.
|
|
|
|
//
|
|
|
|
// @param key Key name.
|
|
|
|
// @param id Id of the found KeyValue.
|
|
|
|
// @return True on success, false if key not found.
|
|
|
|
public native bool GetNameSymbol(const char[] key, int &id);
|
|
|
|
|
|
|
|
// Retrieves the current section id.
|
|
|
|
//
|
|
|
|
// @param kv KeyValues Handle.
|
|
|
|
// @param id Id of the current section.
|
|
|
|
// @return True on success, false on failure.
|
|
|
|
public native bool GetSectionSymbol(int &id);
|
|
|
|
};
|
|
|
|
|
2008-10-04 22:59:11 +02:00
|
|
|
/**
|
|
|
|
* Creates a new KeyValues structure. The Handle must always be closed.
|
|
|
|
*
|
|
|
|
* @param name Name of the root section.
|
|
|
|
* @param firstKey If non-empty, specifies the first key value.
|
|
|
|
* @param firstValue If firstKey is non-empty, specifies the first key's value.
|
|
|
|
* @return A Handle to a new KeyValues structure.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native KeyValues CreateKeyValues(const char[] name, const char[] firstKey="", const char[] firstValue="");
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a string value of a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param value String value.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetString(Handle kv, const char[] key, const char[] value);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets an integer value of a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param value Value number.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetNum(Handle kv, const char[] key, int value);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a large integer value of a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param value Large integer value (0=High bits, 1=Low bits)
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetUInt64(Handle kv, const char[] key, const value[2]);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a floating point value of a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param value Floating point value.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetFloat(Handle kv, const char[] key, float value);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a set of color values of a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param r Red value.
|
|
|
|
* @param g Green value.
|
|
|
|
* @param b Blue value.
|
|
|
|
* @param a Alpha value.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetColor(Handle kv, const char[] key, int r, int g, int b, int a=0);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a vector value of a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param vec Vector value.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetVector(Handle kv, const char[] key, const float vec[3]);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a string value from a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param value Buffer to store key value in.
|
|
|
|
* @param maxlength Maximum length of the value buffer.
|
|
|
|
* @param defvalue Optional default value to use if the key is not found.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvGetString(Handle kv, const char[] key, char[] value, int maxlength, const char[] defvalue="");
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves an integer value from a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param defvalue Optional default value to use if the key is not found.
|
|
|
|
* @return Integer value of the key.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native int KvGetNum(Handle kv, const char[] key, int defvalue=0);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a floating point value from a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param defvalue Optional default value to use if the key is not found.
|
|
|
|
* @return Floating point value of the key.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native float KvGetFloat(Handle kv, const char[] key, float defvalue=0.0);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a set of color values from a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param r Red value, set by reference.
|
|
|
|
* @param g Green value, set by reference.
|
|
|
|
* @param b Blue value, set by reference.
|
|
|
|
* @param a Alpha value, set by reference.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvGetColor(Handle kv, const char[] key, int &r, int &g, int &b, int &a);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a large integer value from a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param value Array to represent the large integer.
|
|
|
|
* @param defvalue Optional default value to use if the key is not found.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvGetUInt64(Handle kv, const char[] key, int value[2], int defvalue[2]={0,0});
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a vector value from a KeyValues key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key, or NULL_STRING.
|
|
|
|
* @param vec Destination vector to store the value in.
|
|
|
|
* @param defvalue Optional default value to use if the key is not found.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvGetVector(Handle kv, const char[] key, float vec[3], const float defvalue[3]={0.0, 0.0, 0.0});
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current position in the KeyValues tree to the given key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key.
|
|
|
|
* @param create If true, and the key does not exist, it will be created.
|
|
|
|
* @return True if the key exists, false if it does not and was not created.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvJumpToKey(Handle kv, const char[] key, bool create=false);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current position in the KeyValues tree to the given key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param id KeyValues id.
|
|
|
|
* @return True if the key exists, false if it does not.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvJumpToKeySymbol(Handle kv, int id);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current position in the KeyValues tree to the first sub key.
|
|
|
|
* This native adds to the internal traversal stack.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param keyOnly If false, non-keys will be traversed (values).
|
|
|
|
* @return True on success, false if there was no first sub key.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvGotoFirstSubKey(Handle kv, bool keyOnly=true);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current position in the KeyValues tree to the next sub key.
|
|
|
|
* This native does NOT add to the internal traversal stack, and thus
|
|
|
|
* KvGoBack() is not needed for each successive call to this function.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param keyOnly If false, non-keys will be traversed (values).
|
|
|
|
* @return True on success, false if there was no next sub key.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvGotoNextKey(Handle kv, bool keyOnly=true);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves the current position in the traversal stack onto the traversal
|
|
|
|
* stack. This can be useful if you wish to use KvGotoNextKey() and
|
|
|
|
* have the previous key saved for backwards traversal.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSavePosition(Handle kv);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes the given key from the current position.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Name of the key.
|
|
|
|
* @return True on success, false if key did not exist.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvDeleteKey(Handle kv, const char[] key);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes the current sub-key and attempts to set the position
|
|
|
|
* to the sub-key after the removed one. If no such sub-key exists,
|
|
|
|
* the position will be the parent key in the traversal stack.
|
|
|
|
* Given the sub-key having position "N" in the traversal stack, the
|
|
|
|
* removal will always take place from position "N-1."
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @return 1 if removal succeeded and there was another key.
|
|
|
|
* 0 if the current node was not contained in the
|
|
|
|
* previous node, or no previous node exists.
|
|
|
|
* -1 if removal succeeded and there were no more keys,
|
|
|
|
* thus the state is as if KvGoBack() was called.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native int KvDeleteThis(Handle kv);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Jumps back to the previous position. Returns false if there are no
|
|
|
|
* previous positions (i.e., at the root node). This should be called
|
|
|
|
* once for each successful Jump call, in order to return to the top node.
|
|
|
|
* This function pops one node off the internal traversal stack.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @return True on success, false if there is no higher node.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvGoBack(Handle kv);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the position back to the top node, emptying the entire node
|
|
|
|
* traversal history. This can be used instead of looping KvGoBack()
|
|
|
|
* if recursive iteration is not important.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvRewind(Handle kv);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves the current section name.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param section Buffer to store the section name.
|
|
|
|
* @param maxlength Maximum length of the name buffer.
|
|
|
|
* @return True on success, false on failure.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvGetSectionName(Handle kv, char[] section, int maxlength);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current section name.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param section Section name.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetSectionName(Handle kv, const char[] section);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the data type at a key.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Key name.
|
|
|
|
* @return KvDataType value of the key.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native KvDataTypes KvGetDataType(Handle kv, const char[] key);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a KeyValues tree to a file. The tree is dumped
|
|
|
|
* from the current position.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param file File to dump write to.
|
|
|
|
* @return True on success, false otherwise.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KeyValuesToFile(Handle kv, const char[] file);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a file to a KeyValues tree. The file is read into
|
|
|
|
* the current position of the tree.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param file File to read from.
|
|
|
|
* @return True on success, false otherwise.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool FileToKeyValues(Handle kv, const char[] file);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a given string to a KeyValues tree. The string is read into
|
|
|
|
* the current postion of the tree.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param buffer String buffer to load into the KeyValues.
|
|
|
|
* @param resourceName The resource name of the KeyValues, used for error tracking purposes.
|
|
|
|
* @return True on success, false otherwise.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
|
|
|
native bool StringToKeyValues(Handle kv, const char[] buffer, const char[] resourceName="StringToKeyValues");
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets whether or not the KeyValues parser will read escape sequences.
|
|
|
|
* For example, \n would be read as a literal newline. This defaults
|
|
|
|
* to false for new KeyValues structures.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param useEscapes Whether or not to read escape sequences.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvSetEscapeSequences(Handle kv, bool useEscapes);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the position in the jump stack; I.e. the number of calls
|
|
|
|
* required for KvGoBack to return to the root node. If at the root node,
|
|
|
|
* 0 is returned.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @return Number of non-root nodes in the jump stack.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native int KvNodesInStack(Handle kv);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Makes a new copy of all subkeys in the origin KeyValues to
|
|
|
|
* the destination KeyValues.
|
|
|
|
* NOTE: All KeyValues are processed from the current location not the root one.
|
|
|
|
*
|
|
|
|
* @param origin Origin KeyValues Handle.
|
2012-01-28 02:16:49 +01:00
|
|
|
* @param dest Destination KeyValues Handle.
|
2008-10-04 22:59:11 +02:00
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native void KvCopySubkeys(Handle origin, Handle dest);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds a KeyValues name by id.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param id KeyValues id.
|
|
|
|
* @param name Buffer to store the name.
|
|
|
|
* @param maxlength Maximum length of the value buffer.
|
|
|
|
* @return True on success, false if id not found.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvFindKeyById(Handle kv, int id, char[] name, int maxlength);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds a KeyValues id inside a KeyValues tree.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param key Key name.
|
|
|
|
* @param id Id of the found KeyValue.
|
|
|
|
* @return True on success, false if key not found.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvGetNameSymbol(Handle kv, const char[] key, int &id);
|
2008-10-04 22:59:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves the current section id.
|
|
|
|
*
|
|
|
|
* @param kv KeyValues Handle.
|
|
|
|
* @param id Id of the current section.
|
|
|
|
* @return True on success, false on failure.
|
|
|
|
* @error Invalid Handle.
|
|
|
|
*/
|
2015-03-21 15:43:24 +01:00
|
|
|
native bool KvGetSectionSymbol(Handle kv, int &id);
|