added: winix functions: locale, timezone
changed: time zones -- now we have the daylight saving time different for each year (start, end) added: config option: time_zone_id (size_t) time zone identifier for not logged users or for newly created accounts those identifiers you can see in etc/time_zones.conf file or by using timezone winix function with 'a' parameter (timezone/a) (!!IMPROVE ME NOT IMPLEMENTED YET) default: 34 (Coordinated Universal Time UTC+00:00) added: config option: locale_default_id (size_t) locale for not logged users or for newly created accounts added: config option: locale_max_id (size_t) a maximum value of a locale identifier default: 100 (maximum: 1000) each locale files should have its own identifier (in "winix_locale_id" field) from zero to this value added: config option: time_zone_max_id (size_t) maximum value of a time zone identifier time zones with an id greater than this will be skipped default: 130 (maximum: 1000) removed: config option: locale_default git-svn-id: svn://ttmath.org/publicrep/winix/trunk@852 e52654a7-88a9-db11-a3e9-0013d4bc506e
This commit is contained in:
@@ -110,6 +110,79 @@ void user_can_use_raw(Info & i)
|
||||
}
|
||||
|
||||
|
||||
void user_has_correct_time_zone(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
i.res = system->time_zones.HasZone(cur->session->puser->time_zone_id);
|
||||
}
|
||||
|
||||
|
||||
void user_time_zone_name(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
{
|
||||
TimeZone * tz = system->time_zones.GetZone(cur->session->puser->time_zone_id);
|
||||
|
||||
if( tz )
|
||||
i.out << locale.Get(tz->name);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void user_time_zone_id(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
i.out << cur->session->puser->time_zone_id;
|
||||
}
|
||||
|
||||
|
||||
void user_time_zone_offset_hour_min(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
{
|
||||
TimeZone * tz = system->time_zones.GetZoneByIndex(cur->session->puser->time_zone_id);
|
||||
|
||||
if( tz )
|
||||
{
|
||||
time_t offset = tz->offset;
|
||||
|
||||
if( offset < 0 )
|
||||
{
|
||||
i.out << '-';
|
||||
offset = -offset;
|
||||
}
|
||||
else
|
||||
{
|
||||
i.out << '+';
|
||||
}
|
||||
|
||||
print_hour_min(i, offset);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void user_has_correct_locale(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
i.res = locale.HasLanguage(cur->session->puser->locale_id);
|
||||
}
|
||||
|
||||
|
||||
void user_locale_name(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
i.out << locale.Get(L"locale_name");
|
||||
}
|
||||
|
||||
|
||||
void user_locale_id(Info & i)
|
||||
{
|
||||
if( cur->session->puser )
|
||||
i.out << cur->session->puser->locale_id;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
static Users::Iterator user_iter;
|
||||
|
Reference in New Issue
Block a user