2018-08-17 01:13:21 -07:00
|
|
|
#pragma once
|
|
|
|
|
2018-08-17 01:34:58 -07:00
|
|
|
#include "ref.hpp"
|
|
|
|
#include "util.hpp"
|
2018-08-17 01:13:21 -07:00
|
|
|
extern "C" {
|
|
|
|
#include "libabacus.h"
|
|
|
|
}
|
|
|
|
|
|
|
|
#define FUNCTION(name) libab_result function_##name( \
|
|
|
|
libab* ab, libab_ref* scope, libab_ref_vec* params, libab_ref* into)
|
|
|
|
|
|
|
|
#define FUNCTION_MPFR(name, func) FUNCTION(name) { \
|
|
|
|
number* value = (number*) libab_unwrap_param(params, 0); \
|
|
|
|
mpfr_t output; \
|
|
|
|
mpfr_init2(output, PRECISION); \
|
|
|
|
mpfr_##func(output, value->value, MPFR_RNDN); \
|
2018-08-17 01:34:58 -07:00
|
|
|
ref to_return = create_value<number>(ab, new number(std::move(output))); \
|
2018-08-17 01:13:21 -07:00
|
|
|
libab_ref_copy(to_return, into); \
|
|
|
|
return LIBAB_SUCCESS; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define FUNCTION_MPFR2(name, func) FUNCTION(name) { \
|
|
|
|
number* left = (number*) libab_unwrap_param(params, 0); \
|
|
|
|
number* right = (number*) libab_unwrap_param(params, 1); \
|
|
|
|
mpfr_t output; \
|
|
|
|
mpfr_init2(output, PRECISION); \
|
|
|
|
mpfr_##func(output, left->value, right->value, MPFR_RNDN); \
|
2018-08-17 01:34:58 -07:00
|
|
|
ref to_return = create_value<number>(ab, new number(std::move(output))); \
|
2018-08-17 01:13:21 -07:00
|
|
|
libab_ref_copy(to_return, into); \
|
|
|
|
return LIBAB_SUCCESS; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define FUNCTION_COMPARE(name, op) FUNCTION(name) { \
|
|
|
|
number* left = (number*) libab_unwrap_param(params, 0); \
|
|
|
|
number* right = (number*) libab_unwrap_param(params, 1); \
|
|
|
|
libab_get_bool_value(ab, mpfr_cmp(left->value, right->value) op 0, into); \
|
|
|
|
return LIBAB_SUCCESS; \
|
|
|
|
}
|
|
|
|
|
|
|
|
FUNCTION(print_string);
|
|
|
|
FUNCTION(to_string_num);
|
|
|
|
FUNCTION(to_string_bool);
|
|
|
|
FUNCTION(to_string_unit);
|
2018-08-17 01:34:58 -07:00
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(plus);
|
|
|
|
FUNCTION(minus);
|
|
|
|
FUNCTION(times);
|
|
|
|
FUNCTION(divide);
|
2018-08-17 01:34:58 -07:00
|
|
|
FUNCTION(pow);
|
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(lt);
|
|
|
|
FUNCTION(lte);
|
|
|
|
FUNCTION(equals);
|
|
|
|
FUNCTION(gt);
|
|
|
|
FUNCTION(gte);
|
2018-08-17 01:34:58 -07:00
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(negate);
|
2018-08-18 17:35:33 -07:00
|
|
|
FUNCTION(factorial);
|
2018-08-17 01:34:58 -07:00
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(ln);
|
|
|
|
FUNCTION(exp);
|
2018-08-17 01:34:58 -07:00
|
|
|
|
2018-08-18 17:41:32 -07:00
|
|
|
FUNCTION(sqrt);
|
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(sin);
|
|
|
|
FUNCTION(cos);
|
|
|
|
FUNCTION(tan);
|
2018-08-17 01:34:58 -07:00
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(arcsin);
|
|
|
|
FUNCTION(arccos);
|
|
|
|
FUNCTION(arctan);
|
2018-08-17 01:34:58 -07:00
|
|
|
|
2018-08-17 01:13:21 -07:00
|
|
|
FUNCTION(quit);
|
|
|
|
FUNCTION(request_precision);
|