- filesystem[meta header]
- std::filesystem[meta namespace]
- function[meta id-type]
- cpp17[meta cpp]
namespace std::filesystem {
path proximate(const path& p, std::error_code& ec); // (1)
path proximate(const path& p, const path& base = current_path()); // (2)
path proximate(const path& p, const path& base, std::error_code& ec); // (3)
}
- path[link path.md]
- current_path()[link current_path.md]
パスを現在の作業ディレクトリからの相対パスに変換する。
- (1) : 現在の作業ディレクトリからパス
p
への相対パスを構築する - (2), (3) : パス
base
からパスp
への相対パスを構築する
この関数の動作はrelative()
関数とほぼ同じだが、対象パスp
と元となるパスの間でパーティションが異なるなどの理由で相対パスの解決に失敗した場合に、空のパスではなく、正規化されたパスp
が返る。
- (1) :
return proximate(p,
current_path()
, ec);
- (2) :
return
weakly_canonical
(p).
lexically_proximate
(
weakly_canonical
(base));
- (3) :
return
weakly_canonical
(p, ec).
lexically_proximate
(
weakly_canonical
(base, ec));
(1)と(3)でエラーが発生した場合、ec
にエラー情報が書き込まれ、path()
が返る。
- (1), (3) : 仕様上は未規定だが、パスのメモリ確保で例外が発生する可能性がある
- (2) : ファイルシステムがエラーを報告する場合がある。それに加えて、指定されたパス
p
とbase
のいずれの部分パスも存在しない場合でもエラーである。エラーが発生した場合は、std::filesystem::filesystem_error
例外を送出する
#include <iostream>
#include <filesystem>
namespace fs = std::filesystem;
int main()
{
// 現在の作業ディレクトリからの相対パスに変換する
fs::path p1 = fs::proximate("/a.txt");
std::cout << p1 << std::endl;
// 現在の作業ディレクトリからひとつ上の階層からの相対パスに変換する
fs::path p2 = fs::proximate("/a.txt", "../");
std::cout << p2 << std::endl;
}
- fs::proximate[color ff0000]
"../../a.txt"
"../a.txt"
- C++17
- Clang: 7.0 [mark verified]
- GCC: 8.1 [mark verified]
- Visual C++: