From af97cfe125d26358d99c1507f1875f7c4aae2119 Mon Sep 17 00:00:00 2001 From: Fernando Pelliccioni Date: Fri, 29 Nov 2024 21:24:10 +0100 Subject: [PATCH] feat: output base directory support for relative paths --- src/lib/Lib/Config.cpp | 16 +++++++++++----- util/generate-config-info.py | 2 +- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/src/lib/Lib/Config.cpp b/src/lib/Lib/Config.cpp index c9da225c8..1e6ad01c6 100644 --- a/src/lib/Lib/Config.cpp +++ b/src/lib/Lib/Config.cpp @@ -92,7 +92,7 @@ struct PublicSettingsVisitor { { // If the path is not absolute, we need to expand it if (!files::isAbsolute(value)) { - auto exp = getBaseDir(value, dirs, useDefault, opts); + auto exp = getBaseDir(value, dirs, self, useDefault, opts); if (!exp) { MRDOCS_TRY(value, files::makeAbsolute(value)); @@ -124,7 +124,7 @@ struct PublicSettingsVisitor { for (auto& v : value) { if (!files::isAbsolute(v)) { - auto exp = getBaseDir(v, dirs, useDefault, opts); + auto exp = getBaseDir(v, dirs, self, useDefault, opts); if (!exp) { MRDOCS_TRY(v, files::makeAbsolute(v)); @@ -187,7 +187,8 @@ struct PublicSettingsVisitor { Expected getBaseDir( std::string_view referenceDirKey, - ReferenceDirectories const& dirs) + ReferenceDirectories const& dirs, + PublicSettings const& settings) { if (referenceDirKey == "config-dir") { return dirs.configDir; @@ -198,6 +199,10 @@ struct PublicSettingsVisitor { else if (referenceDirKey == "mrdocs-root") { return dirs.mrdocsRoot; } + else if (referenceDirKey == "output") { + MRDOCS_ASSERT(!settings.output.empty()); + return settings.output; + } return Unexpected(formatError("unknown relative-to value: \"{}\"", referenceDirKey)); } @@ -218,6 +223,7 @@ struct PublicSettingsVisitor { getBaseDir( std::string& value, ReferenceDirectories const& dirs, + PublicSettings const& settings, bool useDefault, PublicSettings::OptionProperties const& opts) { @@ -226,7 +232,7 @@ struct PublicSettingsVisitor { // as the base path std::string_view relativeTo = opts.relativeto; relativeTo = trimBaseDirReference(relativeTo); - return getBaseDir(relativeTo, dirs); + return getBaseDir(relativeTo, dirs, settings); } // If we used the default value, the base dir comes from @@ -237,7 +243,7 @@ struct PublicSettingsVisitor { referenceDirKey = referenceDirKey.substr(0, pos); } referenceDirKey = trimBaseDirReference(referenceDirKey); - MRDOCS_TRY(std::string_view baseDir, getBaseDir(referenceDirKey, dirs)); + MRDOCS_TRY(std::string_view baseDir, getBaseDir(referenceDirKey, dirs, settings)); if (pos != std::string::npos) { value = value.substr(pos + 1); } diff --git a/util/generate-config-info.py b/util/generate-config-info.py index 808e06dbc..8a7361ea8 100644 --- a/util/generate-config-info.py +++ b/util/generate-config-info.py @@ -139,7 +139,7 @@ def validate_and_normalize_option(option): option['relativeto'] = '' if 'must-exist' not in option: option['must-exist'] = True - reference_directories = ['', '', ''] + reference_directories = ['', '', '', ''] if option['relativeto'] not in reference_directories: raise ValueError(f'Option "{option["name"]}" has an invalid value for "relativeto"') default_paths = option['default']