Scroll to navigation

std::filesystem::path::string,std::filesystem::path::wstring,(3) C++ Standard Libary std::filesystem::path::string,std::filesystem::path::wstring,(3)

NAME

std::filesystem::path::string,std::filesystem::path::wstring, - std::filesystem::path::string,std::filesystem::path::wstring,

Synopsis


std::filesystem::path::u32string


template< class CharT, class Traits =
std::char_traits<CharT>,
(since
class Alloc = std::allocator<CharT> > (1) C++17)
std::basic_string<CharT,Traits,Alloc>


string( const Alloc& a = Alloc() ) const;
std::string string() const;
std::wstring wstring() const;
std::u16string u16string() const;
std::u32string u32string() const;
(2) (since (since
std::string u8string() const; C++17) C++17)
(3) (until
C++20)
std::u8string u8string() const; (since
C++20)


Returns the internal pathname in native pathname format, converted to specific
string type. Conversion, if any, is performed as follows:


* If path::value_type is char, conversion, if any, is system-dependent. This is
the case on typical POSIX systems (such as Linux), where native encoding is
UTF-8 and string() performs no conversion.
* Otherwise, if path::value_type is wchar_t, conversion, if any, is unspecified.
This is the case on Windows, where wchar_t is 16 bit and the native encoding is
UTF-16.
* Otherwise, if path::value_type is char16_t, native encoding is UTF-16 and the
conversion method is unspecified.
* Otherwise, if path::value_type is char32_t, native encoding is UTF-32 and the
conversion method is unspecified.
* Otherwise, if path::value_type is char8_t, native encoding is UTF-8 and the
conversion method is unspecified.
1) All memory allocations are performed by a.
3) The result encoding in the case of u8string() is always UTF-8.

Parameters


(none)

Return value


The internal pathname in native pathname format, converted to specified string type.

Exceptions


May throw implementation-defined exceptions.

Example

// Run this code


#include <clocale>
#include <cstdio>
#include <filesystem>
#include <fstream>
#include <iostream>
#include <locale>


int main()
{
const char* const localeName = "ja_JP.utf-8";
std::setlocale(LC_ALL, localeName);
std::locale::global(std::locale(localeName));


const std::filesystem::path p(u8"要らない.txt");
std::ofstream(p) << "File contents";


// native string representation can be used with OS APIs
if (std::FILE* const f = std::fopen(p.string().c_str(), "r"))
{
for (int ch; (ch = std::fgetc(f)) != EOF;)
std::putchar(ch);


std::fclose(f);
}


// multibyte and wide representation can be used for output
std::cout << "\nFile name in narrow multibyte encoding: " << p.string() << '\n';


// wstring() will throw in stdlibc++ (as per gcc-12.1.0), see:
// https://gcc.gnu.org/bugzilla/show_bug.cgi?id=95048
// https://gcc.gnu.org/bugzilla/show_bug.cgi?id=102839
// works with more recent gcc-12.2.1 (2023/02/01) and clang-10+
std::wcout << "File name in wide encoding: " << p.wstring() << '\n';


std::filesystem::remove(p);
}

Possible output:


File contents
File name in narrow multibyte encoding: 要らない.txt
File name in wide encoding: 要らない.txt

See also


generic_string
generic_wstring returns the path in generic pathname format converted to a string
generic_u8string (public member function)
generic_u16string
generic_u32string

Category:


* Uses of dcl rev begin with nonempty note

2024.06.10 http://cppreference.com