std::messages<CharT>::open, std::messages<CharT>::do_open
| Definiert in Header <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 der am stärksten abgeleiteten Klasse auf.catalog (geerbt von std::messages_base), der an get() übergeben werden kann, um Nachrichten aus dem Nachrichten-Catalog mit dem Namen von name abzurufen. Dieser Wert ist verwendbar, bis er an close() übergeben wird.Inhalt |
[bearbeiten] Parameter
| name | - | Name des zu öffnenden Nachrichten-Catalogs |
| loc | - | Ein Locale-Objekt, das zusätzliche Facetten bereitstellt, die zum Lesen von Nachrichten aus dem Catalog benötigt werden könnten, wie z. B. std::codecvt zur Durchführung von Weit-/Mehrbyte-Konvertierungen. |
[bearbeiten] Rückgabewert
Der nicht-negative Wert vom Typ catalog, der mit get() und close() verwendet werden kann. Gibt einen negativen Wert zurück, wenn der Catalog nicht geöffnet werden konnte.
[bearbeiten] Hinweise
Auf POSIX-Systemen übersetzt dieser Funktionsaufruf normalerweise in einen Aufruf von catopen(). In GNU libstdc++ ruft es textdomain auf.
Der tatsächliche Speicherort des Catalogs ist implementierungsabhängig: für den Catalog "sed" (Nachrichten-Catalogs, die mit dem Unix-Dienstprogramm 'sed' installiert wurden) in der deutschen Locale könnte die von diesem Funktionsaufruf geöffnete Datei beispielsweise /usr/lib/nls/msg/de_DE/sed.cat, /usr/lib/locale/de_DE/LC_MESSAGES/sed.cat oder /usr/share/locale/de/LC_MESSAGES/sed.mo sein.
[bearbeiten] Beispiel
Das folgende Beispiel demonstriert den Abruf von Nachrichten: auf einem typischen GNU/Linux-System liest es aus /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); }
Mögliche Ausgabe
"No match" in German: Keine Übereinstimmung "Memory exhausted" in German: Speicher erschöpft