std::messages<CharT>:: open, std::messages<CharT>:: do_open
|
Определено в заголовочном файле
<locale>
|
||
|
public
:
catalog open ( const std:: string & name, const std:: locale & loc ) const ; |
(1) | |
|
protected
:
virtual catalog do_open ( const std:: string & name, const std:: locale & loc ) const ; |
(2) | |
do_open
самого производного класса.
catalog
(унаследованного от
std::messages_base
), которое может быть передано в
get()
для извлечения сообщений из каталога сообщений с именем
name
. Это значение может использоваться до передачи в
close()
.
Содержание |
Параметры
| name | - | имя открываемого каталога сообщений |
| loc | - | объект локали, предоставляющий дополнительные аспекты, которые могут потребоваться для чтения сообщений из каталога, такие как std::codecvt для выполнения преобразований широких/многобайтовых символов |
Возвращаемое значение
Неотрицательное значение типа
catalog
, которое может использоваться с
get()
и
close()
. Возвращает отрицательное значение, если каталог не может быть открыт.
Примечания
В системах POSIX этот вызов функции обычно преобразуется в вызов
catopen()
. В GNU libstdc++ он вызывает
textdomain
.
Фактическое расположение каталога определяется реализацией: для каталога
"sed"
(каталоги сообщений, установленные с утилитой Unix
'sed'
) в немецкой локали, например, файл, открываемый этим вызовом функции, может быть
/usr/lib/nls/msg/de_DE/sed.cat
,
/usr/lib/locale/de_DE/LC_MESSAGES/sed.cat
, или
/usr/share/locale/de/LC_MESSAGES/sed.mo
.
Пример
Следующий пример демонстрирует получение сообщений: в типичной системе GNU/Linux он читает из
/usr/share/locale/de/LC_MESSAGES/sed.mo
.
#include <iostream> #include <locale> int main() { std::locale loc("de_DE.utf8"); std::cout.imbue(loc); auto& facet = std::use_facet<std::messages<char>>(loc); auto cat = facet.open("sed", loc); if (cat < 0) std::cout << "Could not open german \"sed\" message catalog\n"; else std::cout << "\"No match\" in German: " << facet.get(cat, 0, 0, "No match") << '\n' << "\"Memory exhausted\" in German: " << facet.get(cat, 0, 0, "Memory exhausted") << '\n'; facet.close(cat); }
Возможный вывод:
"No match" in German: Keine Übereinstimmung "Memory exhausted" in German: Speicher erschöpft