summaryrefslogtreecommitdiffstats
path: root/builtin.c
diff options
context:
space:
mode:
authorStephen Dolan <mu@netsoc.tcd.ie>2013-09-14 16:34:52 -0700
committerStephen Dolan <mu@netsoc.tcd.ie>2013-09-14 16:34:52 -0700
commit4e3024cb6149cd04f04c5471c35712411a12bde2 (patch)
tree22df16a76f733aa50dafa370808602d710965d41 /builtin.c
parentdae2422fd18487c89dd79dc54eb4345861ab7bdc (diff)
parentc427bf6a94fb026e8105edc2210dfde0e98c00c2 (diff)
Merge pull request #182 from mdaines/sqrt-builtin
Add builtin for calculating square root
Diffstat (limited to 'builtin.c')
-rw-r--r--builtin.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/builtin.c b/builtin.c
index a61e8204..721cd3fc 100644
--- a/builtin.c
+++ b/builtin.c
@@ -59,6 +59,15 @@ static jv f_floor(jv input) {
return ret;
}
+static jv f_sqrt(jv input) {
+ if (jv_get_kind(input) != JV_KIND_NUMBER) {
+ return type_error(input, "has no square root");
+ }
+ jv ret = jv_number(sqrt(jv_number_value(input)));
+ jv_free(input);
+ return ret;
+}
+
static jv f_negate(jv input) {
if (jv_get_kind(input) != JV_KIND_NUMBER) {
return type_error(input, "cannot be negated");
@@ -474,6 +483,7 @@ static jv f_error(jv input, jv msg) {
static const struct cfunction function_list[] = {
{(cfunction_ptr)f_floor, "_floor", 1},
+ {(cfunction_ptr)f_sqrt, "_sqrt", 1},
{(cfunction_ptr)f_plus, "_plus", 3},
{(cfunction_ptr)f_negate, "_negate", 1},
{(cfunction_ptr)f_minus, "_minus", 3},
@@ -559,6 +569,7 @@ static const char* const jq_builtins[] = {
"def max_by(f): _max_by_impl(map([f]));",
"def min_by(f): _min_by_impl(map([f]));",
"def floor: _floor;",
+ "def sqrt: _sqrt;",
"def add: reduce .[] as $x (null; . + $x);",
"def del(f): delpaths([path(f)]);",
"def _assign(paths; value): value as $v | reduce path(paths) as $p (.; setpath($p; $v));",