File: plugin_event.c

package info (click to toggle)
lcd4linux 0.11.0~svn1203-3
  • links: PTS
  • area: main
  • in suites: bookworm, bullseye, sid, trixie
  • size: 3,064 kB
  • sloc: ansic: 36,586; sh: 4,479; makefile: 209; python: 83; perl: 33
file content (94 lines) | stat: -rw-r--r-- 2,269 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/* $Id: plugin_event.c -1   $
 * $URL: https://ssl.bulix.org/svn/lcd4linux/trunk/plugin_event.c $
 *
 * plugin template
 *
 * Copyright (C) 2003 Ed Martin <edman007@edman007.com>
 * Copyright (C) 2004, 2005, 2006, 2007, 2008 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_event (void)
 *  adds various functions
 *
 */


/* define the include files you need */
#include "config.h"

#include <stdlib.h>
#include <string.h>
#include <ctype.h>

/* these should always be included */
#include "debug.h"
#include "plugin.h"
#include "event.h"

#ifdef WITH_DMALLOC
#include <dmalloc.h>
#endif



/* function 'trigger' */
/* takes one argument, a string */
/* triggers the event */

static void my_trigger(RESULT * result, RESULT * arg1)
{
    char *param;

    /* Get Parameter */
    /* R2N stands for 'Result to Number' */
    param = R2S(arg1);
    named_event_trigger(param);

    char *value = "";

    /* store result */
    /* when called with R_NUMBER, it assumes the */
    /* next parameter to be a pointer to double */
    SetResult(&result, R_NUMBER, &value);
}


/* plugin initialization */
/* MUST NOT be declared 'static'! */
int plugin_init_event(void)
{

    /* register all our cool functions */
    /* the second parameter is the number of arguments */
    /* -1 stands for variable argument list */
    AddFunction("event::trigger", 1, my_trigger);


    return 0;
}

void plugin_exit_event(void)
{
    /* free any allocated memory */
    /* close filedescriptors */
}