aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr/primops.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/libexpr/primops.cc')
-rw-r--r--src/libexpr/primops.cc17
1 files changed, 12 insertions, 5 deletions
diff --git a/src/libexpr/primops.cc b/src/libexpr/primops.cc
index 77721a5a8..c5560be97 100644
--- a/src/libexpr/primops.cc
+++ b/src/libexpr/primops.cc
@@ -390,14 +390,21 @@ static Expr primDirOf(EvalState & state, const ATermVector & args)
}
+ATerm coerceToString(Expr e)
+{
+ ATerm s;
+ if (matchStr(e, s) || matchPath(e, s) || matchUri(e, s))
+ return s;
+ return 0;
+}
+
+
/* Convert the argument (which can be a path or a uri) to a string. */
static Expr primToString(EvalState & state, const ATermVector & args)
{
- Expr arg = evalExpr(state, args[0]);
- ATerm s;
- if (matchStr(arg, s) || matchPath(arg, s) || matchUri(arg, s))
- return makeStr(s);
- throw Error("cannot coerce value to string");
+ ATerm s = coerceToString(evalExpr(state, args[0]));
+ if (!s) throw Error("cannot coerce value to string");
+ return makeStr(s);
}