version 1.25, 2006/01/30 16:17:04
|
version 1.25.2.1, 2006/03/14 20:08:21
|
|
|
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
static char LANGUAGE_TAG_SEPARATOR_CHAR = '-'; | static char LANGUAGE_TAG_SEPARATOR_CHAR = '-'; |
|
static char LOCALE_ID_SEPARATOR_CHAR = '_'; |
| |
AcceptLanguageList LanguageParser::parseAcceptLanguageHeader( | AcceptLanguageList LanguageParser::parseAcceptLanguageHeader( |
const String& acceptLanguageHeader) | const String& acceptLanguageHeader) |
|
|
return clString; | return clString; |
} | } |
| |
|
#ifdef PEGASUS_HAS_ICU |
|
String& LanguageParser::convertLocaleIdToLanguageTag(String& localeId) |
|
{ |
|
Uint32 index = 0; |
|
while ((index = localeId.find(index, LOCALE_ID_SEPARATOR_CHAR)) != |
|
PEG_NOT_FOUND) |
|
{ |
|
localeId[index] = LANGUAGE_TAG_SEPARATOR_CHAR; |
|
} |
|
return localeId; |
|
} |
|
#endif |
|
|
AcceptLanguageList LanguageParser::getDefaultAcceptLanguages() | AcceptLanguageList LanguageParser::getDefaultAcceptLanguages() |
{ | { |
#if defined(PEGASUS_HAS_MESSAGES) && defined(PEGASUS_HAS_ICU) | #if defined(PEGASUS_HAS_MESSAGES) && defined(PEGASUS_HAS_ICU) |
|
|
char* tmp = (char*)default_loc.getName(); | char* tmp = (char*)default_loc.getName(); |
char tmp_[100]; | char tmp_[100]; |
EtoA(strcpy(tmp_,tmp)); | EtoA(strcpy(tmp_,tmp)); |
try |
String localeId = tmp_; |
{ |
|
return LanguageParser::parseAcceptLanguageHeader(tmp_); |
|
} |
|
# else | # else |
|
String localeId = default_loc.getName(); |
|
# endif |
|
|
try | try |
{ | { |
return LanguageParser::parseAcceptLanguageHeader(default_loc.getName()); |
return LanguageParser::parseAcceptLanguageHeader( |
|
convertLocaleIdToLanguageTag(localeId)); |
} | } |
# endif |
|
catch (const InvalidAcceptLanguageHeader& e) | catch (const InvalidAcceptLanguageHeader& e) |
{ | { |
Logger::put_l(Logger::ERROR_LOG, System::CIMSERVER, Logger::SEVERE, | Logger::put_l(Logger::ERROR_LOG, System::CIMSERVER, Logger::SEVERE, |