summaryrefslogtreecommitdiff
path: root/src/buildtool/common
diff options
context:
space:
mode:
Diffstat (limited to 'src/buildtool/common')
-rw-r--r--src/buildtool/common/TARGETS3
-rw-r--r--src/buildtool/common/cli.hpp8
2 files changed, 10 insertions, 1 deletions
diff --git a/src/buildtool/common/TARGETS b/src/buildtool/common/TARGETS
index 4f297a12..4cc2dcbf 100644
--- a/src/buildtool/common/TARGETS
+++ b/src/buildtool/common/TARGETS
@@ -3,7 +3,8 @@
, "name": ["cli"]
, "hdrs": ["cli.hpp"]
, "deps":
- [ ["src/buildtool/compatibility", "compatibility"]
+ [ ["src/buildtool/build_engine/expression", "expression"]
+ , ["src/buildtool/compatibility", "compatibility"]
, ["src/buildtool/logging", "log_level"]
, ["@", "cli11", "", "cli11"]
, ["@", "json", "", "json"]
diff --git a/src/buildtool/common/cli.hpp b/src/buildtool/common/cli.hpp
index adfa3445..b2bd4576 100644
--- a/src/buildtool/common/cli.hpp
+++ b/src/buildtool/common/cli.hpp
@@ -12,6 +12,7 @@
#include "fmt/core.h"
#include "gsl-lite/gsl-lite.hpp"
#include "nlohmann/json.hpp"
+#include "src/buildtool/build_engine/expression/evaluator.hpp"
#include "src/buildtool/compatibility/compatibility.hpp"
#include "src/buildtool/logging/log_level.hpp"
@@ -30,6 +31,7 @@ struct CommonArguments {
/// \brief Arguments required for analysing targets.
struct AnalysisArguments {
+ std::optional<std::size_t> expression_log_limit{};
std::string defines{};
std::filesystem::path config_file{};
std::optional<nlohmann::json> target{};
@@ -137,6 +139,12 @@ static inline auto SetupAnalysisArguments(
gsl::not_null<CLI::App*> const& app,
gsl::not_null<AnalysisArguments*> const& clargs,
bool with_graph = true) {
+ app->add_option("--expression-log-limit",
+ clargs->expression_log_limit,
+ fmt::format("Maximal size for logging a single expression "
+ "in error messages (Default {})",
+ Evaluator::kDefaultExpressionLogLimit))
+ ->type_name("NUM");
app->add_option(
"-D,--defines",
clargs->defines,