summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/report.cc10
-rw-r--r--src/report.h1
2 files changed, 11 insertions, 0 deletions
diff --git a/src/report.cc b/src/report.cc
index 8f06911c..8660ed64 100644
--- a/src/report.cc
+++ b/src/report.cc
@@ -549,6 +549,14 @@ value_t report_t::fn_trim(call_scope_t& args)
}
}
+value_t report_t::fn_format(call_scope_t& args)
+{
+ format_t format(args.get<string>(0));
+ std::ostringstream out;
+ out << format(args);
+ return string_value(out.str());
+}
+
value_t report_t::fn_print(call_scope_t& args)
{
std::ostream& out(output_stream);
@@ -1178,6 +1186,8 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind,
case 'f':
if (is_eq(p, "format_date"))
return MAKE_FUNCTOR(report_t::fn_format_date);
+ else if (is_eq(p, "format"))
+ return MAKE_FUNCTOR(report_t::fn_format);
else if (is_eq(p, "floor"))
return MAKE_FUNCTOR(report_t::fn_floor);
break;
diff --git a/src/report.h b/src/report.h
index 51e35dfa..10138551 100644
--- a/src/report.h
+++ b/src/report.h
@@ -151,6 +151,7 @@ public:
value_t fn_is_seq(call_scope_t& scope);
value_t fn_strip(call_scope_t& scope);
value_t fn_trim(call_scope_t& scope);
+ value_t fn_format(call_scope_t& scope);
value_t fn_print(call_scope_t& scope);
value_t fn_scrub(call_scope_t& scope);
value_t fn_quantity(call_scope_t& scope);