2020-04-21 11:01:03 +10:00
|
|
|
/*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*
|
2022-01-19 12:01:56 +11:00
|
|
|
* Copyright 2022, Danny Robson <danny@nerdcruft.net>
|
2020-04-21 11:01:03 +10:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2022-05-20 11:34:27 +10:00
|
|
|
#include "concepts/named.hpp"
|
|
|
|
|
2020-04-21 11:01:03 +10:00
|
|
|
#include <filesystem>
|
2022-01-19 12:01:56 +11:00
|
|
|
#include <optional>
|
2020-04-21 11:01:03 +10:00
|
|
|
|
|
|
|
|
2022-01-19 12:01:56 +11:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2020-04-21 11:01:03 +10:00
|
|
|
namespace cruft::paths {
|
2022-01-19 12:01:56 +11:00
|
|
|
/// Return the path to the system's temporary directory.
|
|
|
|
std::filesystem::path temp (void);
|
|
|
|
|
|
|
|
|
|
|
|
/// Expand paths that contain platform specific variables
|
|
|
|
///
|
|
|
|
/// eg, "$TMPDIR/foo" and "%HOMEPATH%/foo"
|
2020-04-21 11:01:03 +10:00
|
|
|
std::filesystem::path
|
|
|
|
expand (std::filesystem::path const&);
|
2022-05-20 11:34:27 +10:00
|
|
|
|
|
|
|
|
|
|
|
/// Given a relative path, and a collection of candidate base paths,
|
|
|
|
/// return the first path that exists.
|
|
|
|
///
|
|
|
|
/// Or, if none do, return the relative path itself (if it exists).
|
|
|
|
///
|
|
|
|
/// Else throw a runtime_error.
|
|
|
|
///
|
|
|
|
/// Note: there's a good chance if you're using this then it's likely
|
|
|
|
/// you'll run into TOCTOU errors.
|
|
|
|
template <cruft::concepts::named::container ContainerT>
|
|
|
|
std::filesystem::path
|
|
|
|
resolve_first (std::filesystem::path const &relative, ContainerT bases)
|
|
|
|
{
|
|
|
|
for (auto const &base: bases) {
|
|
|
|
auto const candidate = base / relative;
|
|
|
|
if (std::filesystem::exists (candidate))
|
|
|
|
return candidate;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (exists (relative))
|
|
|
|
return relative;
|
|
|
|
|
|
|
|
throw std::runtime_error ("no path");
|
|
|
|
}
|
2020-04-21 11:01:03 +10:00
|
|
|
}
|