summaryrefslogtreecommitdiffstats
path: root/util/scan/dvb-t/hu-Budapest
diff options
context:
space:
mode:
authoretobi <git@e-tobi.net>2013-09-03 09:48:44 +0200
committeretobi <git@e-tobi.net>2013-09-03 09:48:44 +0200
commit9a5228e0f2b898367b7943d294be58caf6ce8bb3 (patch)
tree8145575f8f67c126b81e607d47613f34add97393 /util/scan/dvb-t/hu-Budapest
parentab959d7b4194715870128e616b8e29d4a101e488 (diff)
downloadlinux-dvb-apps-9a5228e0f2b898367b7943d294be58caf6ce8bb3.tar.gz
Imported Upstream version 1.1.1+rev1273upstream/1.1.1+rev1273
Diffstat (limited to 'util/scan/dvb-t/hu-Budapest')
0 files changed, 0 insertions, 0 deletions
2' href='#n152'>152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
/* $Id$
 * $URL$
 *
 * math plugin
 *
 * Copyright (C) 2003 Michael Reinelt <michael@reinelt.co.at>
 * Copyright (C) 2004 The LCD4Linux Team <lcd4linux-devel@users.sourceforge.net>
 *
 * This file is part of LCD4Linux.
 *
 * LCD4Linux is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2, or (at your option)
 * any later version.
 *
 * LCD4Linux is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 */

/* 
 * exported functions:
 *
 * int plugin_init_math (void)
 *  adds some handy constants and functions
 *
 */


#include "config.h"

#include <stdlib.h>
#include <stdio.h>
#include <math.h>

#include "debug.h"
#include "plugin.h"


static void my_sqrt(RESULT * result, RESULT * arg1)
{
    double value = sqrt(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}

static void my_exp(RESULT * result, RESULT * arg1)
{
    double value = exp(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}

static void my_ln(RESULT * result, RESULT * arg1)
{
    double value = log(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}

static void my_log(RESULT * result, RESULT * arg1)
{
    double value = log10(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}

static void my_sin(RESULT * result, RESULT * arg1)
{
    double value = sin(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}

static void my_cos(RESULT * result, RESULT * arg1)
{
    double value = cos(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}

static void my_tan(RESULT * result, RESULT * arg1)
{
    double value = tan(R2N(arg1));
    SetResult(&result, R_NUMBER, &value);
}


static void my_min(RESULT * result, RESULT * arg1, RESULT * arg2)
{
    double a1 = R2N(arg1);
    double a2 = R2N(arg2);
    double value = a1 < a2 ? a1 : a2;
    SetResult(&result, R_NUMBER, &value);
}

static void my_max(RESULT * result, RESULT * arg1, RESULT * arg2)
{
    double a1 = R2N(arg1);
    double a2 = R2N(arg2);
    double value = a1 > a2 ? a1 : a2;
    SetResult(&result, R_NUMBER, &value);
}

static void my_floor(RESULT * result, RESULT * arg)
{
    double value = floor(R2N(arg));
    SetResult(&result, R_NUMBER, &value);
}

static void my_ceil(RESULT * result, RESULT * arg)
{
    double value = ceil(R2N(arg));
    SetResult(&result, R_NUMBER, &value);
}

static void my_decode(RESULT * result, int argc, RESULT * argv[])
{
    int index;

    if (argc < 2) {
	error("decode(): wrong number of parameters");
	SetResult(&result, R_STRING, "");
	return;
    }

    index = R2N(argv[0]);

    if (index < 0 || index >= argc - 1) {
	SetResult(&result, R_STRING, "");
	return;
    }

    CopyResult(&result, argv[index + 1]);
}


int plugin_init_math(void)
{
    /* set some handy constants */
    SetVariableNumeric("Pi", M_PI);
    SetVariableNumeric("e", M_E);

    /* register some basic math functions */
    AddFunction("sqrt", 1, my_sqrt);
    AddFunction("exp", 1, my_exp);
    AddFunction("ln", 1, my_ln);
    AddFunction("log", 1, my_log);
    AddFunction("sin", 1, my_sin);
    AddFunction("cos", 1, my_cos);
    AddFunction("tan", 1, my_tan);

    /* min, max */
    AddFunction("min", 2, my_min);
    AddFunction("max", 2, my_max);

    /* floor, ceil */
    AddFunction("floor", 1, my_floor);
    AddFunction("ceil", 1, my_ceil);

    /* decode */
    AddFunction("decode", -1, my_decode);

    return 0;
}

void plugin_exit_math(void)
{
}