std::filesystem:: u8path
|
Определено в заголовочном файле
<filesystem>
|
||
|
template
<
class
Source
>
std:: filesystem :: path u8path ( const Source & source ) ; |
(1) |
(начиная с C++17)
(устарело в C++20) |
|
template
<
class
InputIt
>
std:: filesystem :: path u8path ( InputIt first, InputIt last ) ; |
(2) |
(начиная с C++17)
(устарело в C++20) |
Создает путь
p
из UTF-8 кодированной последовательности
char
s
или
char8_t
s
(since C++20)
, предоставленной либо в виде
std::string
, либо в виде
std::string_view
, либо в виде нуль-терминированной многобайтовой строки, либо в виде пары итераторов
[
first, last
)
.
-
Если
path::value_typeявляется char и родная кодировка - UTF-8, конструирует путь напрямую, как если бы через path ( source ) или path ( first, last ) . Примечание: это типичная ситуация для POSIX-систем, использующих Unicode, таких как Linux. -
Иначе, если
path::value_typeявляется wchar_t и родная кодировка - UTF-16 (это ситуация в Windows), или еслиpath::value_typeявляется char16_t (родная кодировка гарантированно UTF-16) или char32_t (родная кодировка гарантированно UTF-32), тогда сначала преобразует UTF-8 последовательность символов во временную строкуtmpтипаpath::string_typeи затем новый путь конструируется как если бы через path ( tmp ) . -
Иначе (для не-UTF-8 узких символьных кодировок и для не-UTF-16
wchar_t
), сначала преобразует UTF-8 последовательность символов во временную строку
tmpтипа std:: u32string с кодировкой UTF-32, и затем новый путь конструируется как если бы через path ( tmp ) (этот путь выбирается в POSIX-системах с не-Unicode многобайтовой или однобайтовой кодировкой файловой системы).
Содержание |
Параметры
| source | - | UTF-8 кодированная std::string , std::string_view , указатель на нуль-терминированную многобайтовую строку, или входной итератор с типом значения char, указывающий на нуль-терминированную многобайтовую строку |
| first, last | - | пара LegacyInputIterator s , задающая UTF-8 кодированную последовательность символов |
| Требования к типам | ||
-
InputIt
должен удовлетворять требованиям
LegacyInputIterator
.
|
||
-
Source
или
InputIt
должен быть
char
или
char8_t
.
(since C++20)
|
||
Возвращаемое значение
Путь, сформированный из входной строки после преобразования из UTF-8 в собственную кодировку символов файловой системы.
Исключения
Может выбросить std::bad_alloc при неудачном выделении памяти.
Примечания
В системах, где собственный формат путей отличается от общего формата путей (ни системы Windows, ни POSIX-системы не являются примерами таких ОС), если аргумент этой функции использует общий формат, он будет преобразован в собственный.
Пример
#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); }
Возможный вывод:
File contents
Смотрите также
|
(C++17)
|
представляет путь
(класс) |