Namensräume
Varianten
Aktionen

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

Von cppreference.com
< cpp‎ | locale‎ | messages
 
 
 
 
 
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)
1) Öffentliche Member-Funktion, ruft die geschützte virtuelle Member-Funktion do_open der am stärksten abgeleiteten Klasse auf.
2) Holt einen Wert vom Typ 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

[bearbeiten] Siehe auch