Add %l format specifier and SetTranslationTarget() native

This commit is contained in:
Arkshine 2015-03-26 16:40:39 +01:00
parent 4d97a24dd8
commit 8831166705
3 changed files with 36 additions and 4 deletions

View File

@ -4431,6 +4431,14 @@ static cell AMX_NATIVE_CALL LookupLangKey(AMX *amx, cell *params)
return 1;
};
// SetGlobalTransTarget(client)
static cell AMX_NATIVE_CALL SetGlobalTransTarget(AMX *amx, cell *params)
{
g_langMngr.SetDefLang(params[1]);
return 1;
};
// has_map_ent_class(const classname[])
static cell AMX_NATIVE_CALL has_map_ent_class(AMX *amx, cell *params)
{
@ -4629,6 +4637,7 @@ AMX_NATIVE_INFO amxmodx_Natives[] =
{"GetLangTransKey", GetLangTransKey},
{"LibraryExists", LibraryExists},
{"LookupLangKey", LookupLangKey},
{"SetGlobalTransTarget", SetGlobalTransTarget},
{"PrepareArray", PrepareArray},
{"ShowSyncHudMsg", ShowSyncHudMsg},
{"is_rukia_a_hag", is_rukia_a_hag},

View File

@ -650,12 +650,22 @@ reswitch:
arg++;
break;
case 'L':
case 'l':
{
cell target;
if (ch == 'L')
{
CHECK_ARGS(1);
cell addr = params[arg++];
target = params[arg++];
}
else
{
CHECK_ARGS(0);
target = g_langMngr.GetDefLang();
}
int len;
const char *key = get_amxstring(amx, params[arg++], 3, len);
const char *def = translate(amx, addr, key);
const char *def = translate(amx, target, key);
if (!def)
{
static char buf[255];

View File

@ -60,3 +60,16 @@ native AddTranslation(const lang[3], TransKey:key, const phrase[]);
* or LANG_SERVER
*/
native LookupLangKey(Output[], OutputSize, const Key[], &id);
/**
* Sets the global language target.
*
* @note This is useful for creating functions
* that will be compatible with the %l format specifier. Note that invalid
* indexes can be specified but the error will occur during translation,
* not during this function call.
*
* @param client Client index or LANG_SERVER
* @noreturn
*/
native SetGlobalTransTarget(client);