std::filesystem::path::string,std::filesystem::path::wstring, (3) - Linux Manuals
std::filesystem::path::string,std::filesystem::path::wstring,: std::filesystem::path::string,std::filesystem::path::wstring,
Command to display std::filesystem::path::string,std::filesystem::path::wstring,
manual in Linux: $ man 3 std::filesystem::path::string,std::filesystem::path::wstring,
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
(none)
Example
// Run this code
#include <cstdio>
#ifdef _MSC_VER
#include <io.h>
#include <fcntl.h>
#else
#include <locale>
#include <clocale>
#endif
#include <fstream>
#include <iostream>
#include <filesystem>
namespace fs = std::filesystem;
int main()
{
#ifdef _MSC_VER
_setmode(_fileno(stderr), _O_WTEXT);
#else
std::setlocale(LC_ALL, "");
std::locale::global(std::locale(""));
std::cout.imbue(std::locale());
std::wcerr.imbue(std::locale());
#endif
fs::path p = fs::u8path(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 APIs
if (std::FILE* f =
#ifdef _MSC_VER
_wfopen(p.c_str(), L"r")
#else
std::fopen(p.c_str(), "r")
#endif
)
{
int ch;
while((ch=fgetc(f))!= EOF) 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';
std::wcerr << "File name in wide encoding: " << p.wstring() << '\n';
fs::remove(p);
}
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
Pages related to std::filesystem::path::string,std::filesystem::path::wstring,
- std::filesystem::path::string,std::filesystem::path::wstring,std::filesystem::path::u8string,std::filesystem::path::u16string,std::filesystem::path::u32string (3) - std::filesystem::path::string,std::filesystem::path::wstring,std::filesystem::path::u8string,std::filesystem::path::u16string,std::filesystem::path::u32string
- std::filesystem::path::stem (3) - std::filesystem::path::stem
- std::filesystem::path::swap (3) - std::filesystem::path::swap
- std::filesystem::path::assign (3) - std::filesystem::path::assign
- std::filesystem::path::begin,std::filesystem::path::end (3) - std::filesystem::path::begin,std::filesystem::path::end
- std::filesystem::path::c_str,std::filesystem::path::native, (3) - std::filesystem::path::c_str,std::filesystem::path::native,
- std::filesystem::path::c_str,std::filesystem::path::native,std::filesystem::path::operatorstring_type() (3) - std::filesystem::path::c_str,std::filesystem::path::native,std::filesystem::path::operatorstring_type()
- std::filesystem::path::clear (3) - std::filesystem::path::clear
- std::filesystem::path::compare (3) - std::filesystem::path::compare
- std::filesystem::path::concat,std::filesystem::path::operator+= (3) - std::filesystem::path::concat,std::filesystem::path::operator+=
- std::filesystem::path::empty (3) - std::filesystem::path::empty
- std::filesystem::path::extension (3) - std::filesystem::path::extension
- std::filesystem::path::filename (3) - std::filesystem::path::filename
- std::filesystem::path::format (3) - std::filesystem::path::format
- std::filesystem::path::generic_string,std::filesystem::path::generic_wstring, (3) - std::filesystem::path::generic_string,std::filesystem::path::generic_wstring,
- std::filesystem::path::has_root_path,std::filesystem::path::has_root_name, (3) - std::filesystem::path::has_root_path,std::filesystem::path::has_root_name,
- std::filesystem::path::is_absolute,is_relative (3) - std::filesystem::path::is_absolute,is_relative
- std::filesystem::path::lexically_normal,std::filesystem::path::lexically_relative, (3) - std::filesystem::path::lexically_normal,std::filesystem::path::lexically_relative,
- std::filesystem::path::lexically_normal,std::filesystem::path::lexically_relative,std::filesystem::path::lexically_proximate (3) - std::filesystem::path::lexically_normal,std::filesystem::path::lexically_relative,std::filesystem::path::lexically_proximate
- std::filesystem::path::make_preferred (3) - std::filesystem::path::make_preferred
- std::filesystem::path::operator= (3) - std::filesystem::path::operator=
- std::filesystem::path::parent_path (3) - std::filesystem::path::parent_path
- std::filesystem::path::path (3) - std::filesystem::path::path
- std::filesystem::path::relative_path (3) - std::filesystem::path::relative_path
- std::filesystem::path::remove_filename (3) - std::filesystem::path::remove_filename
- std::filesystem::path::replace_extension (3) - std::filesystem::path::replace_extension
- std::filesystem::path::replace_filename (3) - std::filesystem::path::replace_filename