mirror of https://github.com/OpenTTD/OpenTTD
(svn r16946) -Doc: Adding docs for some string parameter manipulation functions.
parent
63f2da7492
commit
59c48fee8b
|
@ -35,8 +35,8 @@
|
||||||
#include "table/strings.h"
|
#include "table/strings.h"
|
||||||
#include "table/control_codes.h"
|
#include "table/control_codes.h"
|
||||||
|
|
||||||
DynamicLanguages _dynlang;
|
DynamicLanguages _dynlang; ///< Language information of the program.
|
||||||
uint64 _decode_parameters[20];
|
uint64 _decode_parameters[20]; ///< Global array of string parameters. To access, use #SetDParam.
|
||||||
|
|
||||||
static char *StationGetSpecialString(char *buff, int x, const char *last);
|
static char *StationGetSpecialString(char *buff, int x, const char *last);
|
||||||
static char *GetSpecialTownNameString(char *buff, int ind, uint32 seed, const char *last);
|
static char *GetSpecialTownNameString(char *buff, int ind, uint32 seed, const char *last);
|
||||||
|
@ -171,6 +171,10 @@ void SetDParamStr(uint n, const char *str)
|
||||||
SetDParam(n, (uint64)(size_t)str);
|
SetDParam(n, (uint64)(size_t)str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shift the string parameters in the global string parameter array by \a amount positions, making room at the beginning.
|
||||||
|
* @param amount Number of positions to shift.
|
||||||
|
*/
|
||||||
void InjectDParam(uint amount)
|
void InjectDParam(uint amount)
|
||||||
{
|
{
|
||||||
assert((uint)amount < lengthof(_decode_parameters));
|
assert((uint)amount < lengthof(_decode_parameters));
|
||||||
|
|
|
@ -13,11 +13,22 @@ const char *GetStringPtr(StringID string);
|
||||||
|
|
||||||
void InjectDParam(uint amount);
|
void InjectDParam(uint amount);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a string parameter \a v at index \a n in a given array \a s.
|
||||||
|
* @param s Array of string parameters.
|
||||||
|
* @param n Index of the string parameter.
|
||||||
|
* @param v Value of the string parameter.
|
||||||
|
*/
|
||||||
static inline void SetDParamX(uint64 *s, uint n, uint64 v)
|
static inline void SetDParamX(uint64 *s, uint n, uint64 v)
|
||||||
{
|
{
|
||||||
s[n] = v;
|
s[n] = v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a string parameter \a v at index \a n in the global string parameter array.
|
||||||
|
* @param n Index of the string parameter.
|
||||||
|
* @param v Value of the string parameter.
|
||||||
|
*/
|
||||||
static inline void SetDParam(uint n, uint64 v)
|
static inline void SetDParam(uint n, uint64 v)
|
||||||
{
|
{
|
||||||
extern uint64 _decode_parameters[20];
|
extern uint64 _decode_parameters[20];
|
||||||
|
@ -28,11 +39,23 @@ static inline void SetDParam(uint n, uint64 v)
|
||||||
|
|
||||||
void SetDParamStr(uint n, const char *str);
|
void SetDParamStr(uint n, const char *str);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the current string parameter at index \a n from parameter array \a s.
|
||||||
|
* @param s Array of string parameters.
|
||||||
|
* @param n Index of the string parameter.
|
||||||
|
* @return Value of the requested string parameter.
|
||||||
|
*/
|
||||||
static inline uint64 GetDParamX(const uint64 *s, uint n)
|
static inline uint64 GetDParamX(const uint64 *s, uint n)
|
||||||
{
|
{
|
||||||
return s[n];
|
return s[n];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the current string parameter at index \a n from the global string parameter array.
|
||||||
|
* @param s Array of string parameters.
|
||||||
|
* @param n Index of the string parameter.
|
||||||
|
* @return Value of the requested string parameter.
|
||||||
|
*/
|
||||||
static inline uint64 GetDParam(uint n)
|
static inline uint64 GetDParam(uint n)
|
||||||
{
|
{
|
||||||
extern uint64 _decode_parameters[20];
|
extern uint64 _decode_parameters[20];
|
||||||
|
@ -41,12 +64,24 @@ static inline uint64 GetDParam(uint n)
|
||||||
return _decode_parameters[n];
|
return _decode_parameters[n];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy \a num string parameters from array \a src into the global string parameter array.
|
||||||
|
* @param offs Index in the global array to copy the first string parameter to.
|
||||||
|
* @param src Source array of string parameters.
|
||||||
|
* @param num Number of string parameters to copy.
|
||||||
|
*/
|
||||||
static inline void CopyInDParam(int offs, const uint64 *src, int num)
|
static inline void CopyInDParam(int offs, const uint64 *src, int num)
|
||||||
{
|
{
|
||||||
extern uint64 _decode_parameters[20];
|
extern uint64 _decode_parameters[20];
|
||||||
memcpy(_decode_parameters + offs, src, sizeof(uint64) * (num));
|
memcpy(_decode_parameters + offs, src, sizeof(uint64) * (num));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy \a num string parameters from the global string parameter array to the \a dst array.
|
||||||
|
* @param dst Destination array of string parameters.
|
||||||
|
* @param offs Index in the global array to copy the first string parameter from.
|
||||||
|
* @param num Number of string parameters to copy.
|
||||||
|
*/
|
||||||
static inline void CopyOutDParam(uint64 *dst, int offs, int num)
|
static inline void CopyOutDParam(uint64 *dst, int offs, int num)
|
||||||
{
|
{
|
||||||
extern uint64 _decode_parameters[20];
|
extern uint64 _decode_parameters[20];
|
||||||
|
|
Loading…
Reference in New Issue