#include <ejit/ejit.h>
#include <assert.h>
#include "do_jit.h"

int main(int argc, char *argv[])
{
        (void)argv;
        bool do_jit = argc > 1;
        struct ejit_operand operands[1] = {
                EJIT_OPERAND_FPR(0, EJIT_TYPE(double)),
        };
        struct ejit_func *f = ejit_create_func(EJIT_TYPE(double), 1, operands);

        ejit_sqrtr_d(f, EJIT_FPR(0), EJIT_FPR(0));
        ejit_retr_d(f, EJIT_FPR(0));

        ejit_select_compile_func(f, 0, 1, EJIT_USE64(double), do_jit, true);

        assert(erfd1(f, EJIT_ARG( 0.0, double)) == 0.0);
        assert(erfd1(f, EJIT_ARG( 4.0, double)) == 2.0);
        assert(erfd1(f, EJIT_ARG(-4.0, double))
                        != erfd1(f, EJIT_ARG(-4.0, double))); // nan
}