summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorKlaus Aehlig <klaus.aehlig@huawei.com>2023-08-14 12:13:05 +0200
committerKlaus Aehlig <klaus.aehlig@huawei.com>2023-08-14 12:43:35 +0200
commitcbe7bde952b4ed5d910e9a152f953ba172c5f654 (patch)
tree729f58fb6f26fe5b906e822d58030fb9a399e5dd /src
parent726e70cb9bf544ee3164e32405e4dd4f750c0403 (diff)
downloadjustbuild-cbe7bde952b4ed5d910e9a152f953ba172c5f654.tar.gz
expression: add new built in "reverse"
While a foldl is enough to implement a reverse functionality, adding it as a built in allows doing so in linear time.
Diffstat (limited to 'src')
-rw-r--r--src/buildtool/build_engine/expression/evaluator.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/buildtool/build_engine/expression/evaluator.cpp b/src/buildtool/build_engine/expression/evaluator.cpp
index 431792e8..1d207b3b 100644
--- a/src/buildtool/build_engine/expression/evaluator.cpp
+++ b/src/buildtool/build_engine/expression/evaluator.cpp
@@ -185,6 +185,16 @@ auto Set(ExpressionPtr const& expr) -> ExpressionPtr {
return ExpressionPtr{Expression::map_t{result}};
}
+auto Reverse(ExpressionPtr const& expr) -> ExpressionPtr {
+ if (not expr->IsList()) {
+ throw Evaluator::EvaluationError{fmt::format(
+ "reverse expects list but instead got: {}.", expr->ToString())};
+ }
+ auto reverse_result = Expression::list_t(expr->List());
+ std::reverse(reverse_result.begin(), reverse_result.end());
+ return ExpressionPtr{reverse_result};
+}
+
auto NubRight(ExpressionPtr const& expr) -> ExpressionPtr {
if (not expr->IsList()) {
throw Evaluator::EvaluationError{fmt::format(
@@ -957,6 +967,7 @@ auto const kBuiltInFunctions =
{"keys", UnaryExpr(Keys)},
{"enumerate", UnaryExpr(Enumerate)},
{"set", UnaryExpr(Set)},
+ {"reverse", UnaryExpr(Reverse)},
{"values", UnaryExpr(Values)},
{"lookup", LookupExpr},
{"empty_map", EmptyMapExpr},