命名空间
变体
操作

std::messages<CharT>::open, std::messages<CharT>::do_open

来自 cppreference.com
< cpp‎ | locale‎ | messages
 
 
 
 
定义在头文件 <locale>
public:
catalog open( const std::basic_string<char>& name, const std::locale& loc ) const;
(1)
protected:
virtual catalog do_open( const std::basic_string<char>& name, const std::locale& loc ) const;
(2)
1) 公共成员函数,调用最派生类的受保护的虚拟成员函数 do_open
2) 获取类型为 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

[编辑] 参见