int compare( const path& p ) const; | (1) | (since C++17) |
int compare( const string_type& str ) const; int compare( std::basic_string_view<value_type> str ) const; | (2) | (since C++17) |
int compare( const value_type* s ) const; | (3) | (since C++17) |
Compares the lexical representations of the path and another path.
p
(p.native()
). Comparison is performed element-wise, as if by iterating both paths from begin() to end().compare(path(str))
.compare(path(s))
.p | - | a path to compare to |
str | - | a string or string view representing path to compare to |
s | - | a null-terminated string representing path to compare to |
A value less than 0 if the path is lexicographically less than the given path.
A value equal to 0 if the path is lexicographically equal to the given path.
A value greater than 0 if the path is lexicographically greater than the given path.
noexcept
specification: noexcept
For two-way comparisons, binary operators may be more suitable.
#include <iostream> #include <filesystem> namespace fs = std::filesystem; void demo(int rc, fs::path p1, fs::path p2) { if(rc < 0) std::cout << p1 << " < " << p2 << '\n'; else if(rc > 0) std::cout << p1 << " > " << p2 << '\n'; else if(rc == 0) std::cout << p1 << "==" << p2 << '\n'; } int main() { fs::path p1 = "/a/b/"; // as if "a/b/." for lexicographical iteration fs::path p2 = "/a/b/#"; demo(p1.compare(p2), p1, p2); demo(p1.compare("a/b/_"), p1, "a/b/_"); }
Output:
"/a/b/" > "/a/b/#" "/a/b/" < "a/b/_"
lexicographically compares two paths (function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/cpp/filesystem/path/compare