From 552041beda9baa69e490290436e3ff6e089506f8 Mon Sep 17 00:00:00 2001 From: lfcorreia Date: Sat, 29 Jul 2006 21:12:31 +0000 Subject: [lcd4linux @ 2006-07-29 21:12:31 by lfcorreia] Add UPPERCASE string plugin function git-svn-id: https://ssl.bulix.org/svn/lcd4linux/trunk@677 3ae390bd-cb1e-0410-b409-cd5a39f66f1f --- plugin_string.c | 46 +++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 45 insertions(+), 1 deletion(-) (limited to 'plugin_string.c') diff --git a/plugin_string.c b/plugin_string.c index e1fd0a4..464d9e8 100644 --- a/plugin_string.c +++ b/plugin_string.c @@ -1,4 +1,4 @@ -/* $Id: plugin_string.c,v 1.8 2005/05/08 04:32:45 reinelt Exp $ +/* $Id: plugin_string.c,v 1.9 2006/07/29 21:12:31 lfcorreia Exp $ * * string plugin * @@ -23,6 +23,9 @@ * * * $Log: plugin_string.c,v $ + * Revision 1.9 2006/07/29 21:12:31 lfcorreia + * Add UPPERCASE string plugin function + * * Revision 1.8 2005/05/08 04:32:45 reinelt * CodingStyle added and applied * @@ -96,3 +99,44 @@ void plugin_exit_string(void) { /* empty */ } + +/* 'upcase' function (shamelessly stolen from plugin_sample.c)*/ +/* takes one argument, a string */ +/* returns the string in upper case letters */ + +static void my_upcase(RESULT * result, RESULT * arg1) +{ + char *value, *p; + + /* create a local copy of the argument */ + /* Do *NOT* try to modify the original string! */ + value = strdup(R2S(arg1)); + + /* process the string */ + for (p = value; *p != '\0'; p++) + *p = toupper(*p); + + /* store result */ + /* when called with R_STRING, it assumes the */ + /* next parameter to be a pointer to a string */ + /* 'value' is already a char*, so use 'value', not '&value' */ + SetResult(&result, R_STRING, value); + + /* free local copy again */ + /* Note that SetResult() makes its own string copy */ + free(value); +} + +int plugin_init_strupper(void) +{ + + /* register my UPPERCASE transforming function */ + AddFunction("strupper", 1, my_upcase); + + return 0; +} + +void plugin_exit_strupper(void) +{ + /* empty */ +} -- cgit v1.2.3