mirror of
				git://git.code.sf.net/p/zsh/code
				synced 2025-10-26 04:30:27 +01:00 
			
		
		
		
	Shell functions are strictly ASCII for maximum portability. Other files within the distribution may contain UTF-8 characters. Exception for test files: where they need single character input with the top bit set, ISO-8859-X is used (X doesn't matter as we don't need the Euro).
		
			
				
	
	
		
			247 lines
		
	
	
	
		
			5.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			247 lines
		
	
	
	
		
			5.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * example.c - an example module for zsh
 | |
|  *
 | |
|  * This file is part of zsh, the Z shell.
 | |
|  *
 | |
|  * Copyright (c) 1996-1997 Zoltán Hidvégi
 | |
|  * All rights reserved.
 | |
|  *
 | |
|  * Permission is hereby granted, without written agreement and without
 | |
|  * license or royalty fees, to use, copy, modify, and distribute this
 | |
|  * software and to distribute modified versions of this software for any
 | |
|  * purpose, provided that the above copyright notice and the following
 | |
|  * two paragraphs appear in all copies of this software.
 | |
|  *
 | |
|  * In no event shall Zoltán Hidvégi or the Zsh Development Group be liable
 | |
|  * to any party for direct, indirect, special, incidental, or consequential
 | |
|  * damages arising out of the use of this software and its documentation,
 | |
|  * even if Zoltán Hidvégi and the Zsh Development Group have been advised of
 | |
|  * the possibility of such damage.
 | |
|  *
 | |
|  * Zoltán Hidvégi and the Zsh Development Group specifically disclaim any
 | |
|  * warranties, including, but not limited to, the implied warranties of
 | |
|  * merchantability and fitness for a particular purpose.  The software
 | |
|  * provided hereunder is on an "as is" basis, and Zoltán Hidvégi and the
 | |
|  * Zsh Development Group have no obligation to provide maintenance,
 | |
|  * support, updates, enhancements, or modifications.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include "example.mdh"
 | |
| #include "example.pro"
 | |
| 
 | |
| /* parameters */
 | |
| 
 | |
| static zlong intparam;
 | |
| static char *strparam;
 | |
| static char **arrparam;
 | |
| 
 | |
| 
 | |
| /**/
 | |
| static int
 | |
| bin_example(char *nam, char **args, Options ops, UNUSED(int func))
 | |
| {
 | |
|     unsigned char c;
 | |
|     char **oargs = args, **p = arrparam;
 | |
|     long i = 0;
 | |
| 
 | |
|     printf("Options: ");
 | |
|     for (c = 32; ++c < 128;)
 | |
| 	if (OPT_ISSET(ops,c))
 | |
| 	    putchar(c);
 | |
|     printf("\nArguments:");
 | |
|     for (; *args; i++, args++) {
 | |
| 	putchar(' ');
 | |
| 	fputs(*args, stdout);
 | |
|     }
 | |
|     printf("\nName: %s\n", nam);
 | |
| #ifdef ZSH_64_BIT_TYPE
 | |
|     printf("\nInteger Parameter: %s\n", output64(intparam));
 | |
| #else
 | |
|     printf("\nInteger Parameter: %ld\n", intparam);
 | |
| #endif
 | |
|     printf("String Parameter: %s\n", strparam ? strparam : "");
 | |
|     printf("Array Parameter:");
 | |
|     if (p)
 | |
| 	while (*p) printf(" %s", *p++);
 | |
|     printf("\n");
 | |
| 
 | |
|     intparam = i;
 | |
|     zsfree(strparam);
 | |
|     strparam = ztrdup(*oargs ? *oargs : "");
 | |
|     freearray(arrparam);
 | |
|     arrparam = zarrdup(oargs);
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| /**/
 | |
| static int
 | |
| cond_p_len(char **a, UNUSED(int id))
 | |
| {
 | |
|     char *s1 = cond_str(a, 0, 0);
 | |
| 
 | |
|     if (a[1]) {
 | |
| 	zlong v = cond_val(a, 1);
 | |
| 
 | |
| 	return strlen(s1) == v;
 | |
|     } else {
 | |
| 	return !s1[0];
 | |
|     }
 | |
| }
 | |
| 
 | |
| /**/
 | |
| static int
 | |
| cond_i_ex(char **a, UNUSED(int id))
 | |
| {
 | |
|     char *s1 = cond_str(a, 0, 0), *s2 = cond_str(a, 1, 0);
 | |
| 
 | |
|     return !strcmp("example", dyncat(s1, s2));
 | |
| }
 | |
| 
 | |
| /**/
 | |
| static mnumber
 | |
| math_sum(UNUSED(char *name), int argc, mnumber *argv, UNUSED(int id))
 | |
| {
 | |
|     mnumber ret;
 | |
|     int f = 0;
 | |
| 
 | |
|     ret.u.l = 0;
 | |
|     while (argc--) {
 | |
| 	if (argv->type == MN_INTEGER) {
 | |
| 	    if (f)
 | |
| 		ret.u.d += (double) argv->u.l;
 | |
| 	    else
 | |
| 		ret.u.l += argv->u.l;
 | |
| 	} else {
 | |
| 	    if (f)
 | |
| 		ret.u.d += argv->u.d;
 | |
| 	    else {
 | |
| 		ret.u.d = ((double) ret.u.l) + ((double) argv->u.d);
 | |
| 		f = 1;
 | |
| 	    }
 | |
| 	}
 | |
| 	argv++;
 | |
|     }
 | |
|     ret.type = (f ? MN_FLOAT : MN_INTEGER);
 | |
| 
 | |
|     return ret;
 | |
| }
 | |
| 
 | |
| /**/
 | |
| static mnumber
 | |
| math_length(UNUSED(char *name), char *arg, UNUSED(int id))
 | |
| {
 | |
|     mnumber ret;
 | |
| 
 | |
|     ret.type = MN_INTEGER;
 | |
|     ret.u.l = strlen(arg);
 | |
| 
 | |
|     return ret;
 | |
| }
 | |
| 
 | |
| /**/
 | |
| static int
 | |
| ex_wrapper(Eprog prog, FuncWrap w, char *name)
 | |
| {
 | |
|     if (strncmp(name, "example", 7))
 | |
| 	return 1;
 | |
|     else {
 | |
| 	int ogd = opts[GLOBDOTS];
 | |
| 
 | |
| 	opts[GLOBDOTS] = 1;
 | |
| 	runshfunc(prog, w, name);
 | |
| 	opts[GLOBDOTS] = ogd;
 | |
| 
 | |
| 	return 0;
 | |
|     }
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * boot_ is executed when the module is loaded.
 | |
|  */
 | |
| 
 | |
| static struct builtin bintab[] = {
 | |
|     BUILTIN("example", 0, bin_example, 0, -1, 0, "flags", NULL),
 | |
| };
 | |
| 
 | |
| static struct conddef cotab[] = {
 | |
|     CONDDEF("ex", CONDF_INFIX, cond_i_ex, 0, 0, 0),
 | |
|     CONDDEF("len", 0, cond_p_len, 1, 2, 0),
 | |
| };
 | |
| 
 | |
| static struct paramdef patab[] = {
 | |
|     ARRPARAMDEF("exarr", &arrparam),
 | |
|     INTPARAMDEF("exint", &intparam),
 | |
|     STRPARAMDEF("exstr", &strparam),
 | |
| };
 | |
| 
 | |
| static struct mathfunc mftab[] = {
 | |
|     STRMATHFUNC("length", math_length, 0),
 | |
|     NUMMATHFUNC("sum", math_sum, 1, -1, 0),
 | |
| };
 | |
| 
 | |
| static struct funcwrap wrapper[] = {
 | |
|     WRAPDEF(ex_wrapper),
 | |
| };
 | |
| 
 | |
| static struct features module_features = {
 | |
|     bintab, sizeof(bintab)/sizeof(*bintab),
 | |
|     cotab, sizeof(cotab)/sizeof(*cotab),
 | |
|     mftab, sizeof(mftab)/sizeof(*mftab),
 | |
|     patab, sizeof(patab)/sizeof(*patab),
 | |
|     0
 | |
| };
 | |
| 
 | |
| /**/
 | |
| int
 | |
| setup_(UNUSED(Module m))
 | |
| {
 | |
|     printf("The example module has now been set up.\n");
 | |
|     fflush(stdout);
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| /**/
 | |
| int
 | |
| features_(Module m, char ***features)
 | |
| {
 | |
|     *features = featuresarray(m, &module_features);
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| /**/
 | |
| int
 | |
| enables_(Module m, int **enables)
 | |
| {
 | |
|     return handlefeatures(m, &module_features, enables);
 | |
| }
 | |
| 
 | |
| /**/
 | |
| int
 | |
| boot_(Module m)
 | |
| {
 | |
|     intparam = 42;
 | |
|     strparam = ztrdup("example");
 | |
|     arrparam = (char **) zalloc(3 * sizeof(char *));
 | |
|     arrparam[0] = ztrdup("example");
 | |
|     arrparam[1] = ztrdup("array");
 | |
|     arrparam[2] = NULL;
 | |
|     return addwrapper(m, wrapper);
 | |
| }
 | |
| 
 | |
| /**/
 | |
| int
 | |
| cleanup_(Module m)
 | |
| {
 | |
|     deletewrapper(m, wrapper);
 | |
|     return setfeatureenables(m, &module_features, NULL);
 | |
| }
 | |
| 
 | |
| /**/
 | |
| int
 | |
| finish_(UNUSED(Module m))
 | |
| {
 | |
|     printf("Thank you for using the example module.  Have a nice day.\n");
 | |
|     fflush(stdout);
 | |
|     return 0;
 | |
| }
 |