Namensräume
Varianten
Aktionen

std::filesystem::u8path

Von cppreference.com
< cpp‎ | filesystem‎ | path
 
 
 
 
Definiert in Header <filesystem>
template< class Source >
std::filesystem::path u8path( const Source& source );
(1) (seit C++17)
(veraltet in C++20)
template< class InputIt >
std::filesystem::path u8path( InputIt first, InputIt last );
(2) (seit C++17)
(veraltet in C++20)

Konstruiert einen Pfad p aus einer UTF-8-kodierten Sequenz von chars oder char8_ts(seit C++20), entweder als std::string, std::string_view, als nullterminierte Multibyte-Zeichenkette oder als [first, last)-Iteratorenpaar.

  • Wenn path::value_type char ist und die native Kodierung UTF-8 ist, wird ein Pfad direkt konstruiert, als ob durch path(source) oder path(first, last). Hinweis: Dies ist die typische Situation eines POSIX-Systems, das Unicode verwendet, wie z. B. Linux.
  • Andernfalls, wenn path::value_type wchar_t ist und die native Kodierung UTF-16 ist (dies ist die Situation unter Windows), oder wenn path::value_type char16_t (native Kodierung garantiert UTF-16) oder char32_t (native Kodierung garantiert UTF-32) ist, dann wird die UTF-8-Zeichensequenz zuerst in eine temporäre Zeichenkette tmp vom Typ path::string_type konvertiert und dann der neue Pfad konstruiert, als ob durch path(tmp).
  • Andernfalls (für Nicht-UTF-8-Schmalzeichenkodierungen und für Nicht-UTF-16 wchar_t) wird die UTF-8-Zeichensequenz zuerst in eine temporäre UTF-32-kodierte Zeichenkette tmp vom Typ std::u32string konvertiert und dann der neue Pfad konstruiert, als ob durch path(tmp) (dieser Pfad wird auf einem POSIX-System mit einem nicht-Unicode-Multibyte- oder Single-Byte-kodierten Dateisystem genommen).

Inhalt

[edit] Parameter

source - eine UTF-8-kodierte std::string, std::string_view, ein Zeiger auf eine nullterminierte Multibyte-Zeichenkette oder ein Eingabeiterator mit `char`-Werttyp, der auf eine nullterminierte Multibyte-Zeichenkette zeigt
first, last - Paar von LegacyInputIterators, die eine UTF-8-kodierte Zeichensequenz spezifizieren
Typanforderungen
-
InputIt muss die Anforderungen von LegacyInputIterator erfüllen.
-
Der Werttyp von Source oder InputIt muss char oder char8_t(seit C++20) sein.

[edit] Rückgabewert

Der aus der Eingabezeichenkette konstruierte Pfad nach der Konvertierung von UTF-8 in die native Zeichenkodierung des Dateisystems.

[edit] Ausnahmen

Kann std::bad_alloc auslösen, wenn die Speicherzuweisung fehlschlägt.

[edit] Anmerkungen

Auf Systemen, bei denen das native Pfadformat vom generischen Pfadformat abweicht (weder Windows noch POSIX-Systeme sind Beispiele für solche Betriebssysteme), wird, wenn das Argument dieser Funktion das generische Format verwendet, dieses in das native Format konvertiert.

[edit] Beispiel

#include <cstdio>
#ifdef _MSC_VER
#include <fcntl.h>
#include <io.h>
#else
#include <clocale>
#include <locale>
#endif
#include <filesystem>
#include <fstream>
 
int main()
{
#ifdef _MSC_VER
    _setmode(_fileno(stderr), _O_WTEXT);
#else
    std::setlocale(LC_ALL, "");
    std::locale::global(std::locale(""));
#endif
 
    std::filesystem::path p(u8"要らない.txt");
    std::ofstream(p) << "File contents"; // Prior to LWG2676 uses operator string_type()
                                         // on MSVC, where string_type is wstring, only
                                         // works due to non-standard extension.
                                         // Post-LWG2676 uses new fstream constructors
 
    // Native string representation can be used with OS-specific APIs
#ifdef _MSC_VER
    if (std::FILE* f = _wfopen(p.c_str(), L"r"))
#else
    if (std::FILE* f = std::fopen(p.c_str(), "r"))
#endif
    {
        for (int ch; (ch = fgetc(f)) != EOF; std::putchar(ch))
        {}
        std::fclose(f);
    }
 
    std::filesystem::remove(p);
}

Mögliche Ausgabe

File contents

[edit] Siehe auch

(C++17)
repräsentiert einen Pfad
(Klasse) [bearbeiten]