/* : : generated by proto : : */ /*********************************************************************** * * * This software is part of the ast package * * Copyright (c) 1985-2008 AT&T Intellectual Property * * and is licensed under the * * Common Public License, Version 1.0 * * by AT&T Intellectual Property * * * * A copy of the License is available at * * http://www.opensource.org/licenses/cpl1.0.txt * * (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9) * * * * Information and Software Systems Research * * AT&T Research * * Florham Park NJ * * * * Glenn Fowler * * David Korn * * Phong Vo * * * ***********************************************************************/ /* * ksh builtin command api */ #ifndef _SHCMD_H #if !defined(__PROTO__) #include #endif #if !defined(__LINKAGE__) #define __LINKAGE__ /* 2004-08-11 transition */ #endif #define _SHCMD_H 1 #ifndef SH_VERSION # define Shell_t void #endif #ifndef NV_DEFAULT # define Namval_t void #endif #ifndef ERROR_NOTIFY # define ERROR_NOTIFY 1 #endif typedef int (*Shbltin_f) __PROTO__((int, char**, __V_*)); #undef Shbltin_t typedef struct Shbltin_s { Shell_t *shp; __V_ *ptr; int version; int (*shrun) __PROTO__((int, char**)); int (*shtrap) __PROTO__((const char*, int)); void (*shexit) __PROTO__((int)); Namval_t *(*shbltin) __PROTO__((const char*, Shbltin_f, __V_*)); unsigned char notify; unsigned char sigset; unsigned char nosfio; Namval_t *bnode; Namval_t *vnode; char *data; int flags; char *(*shgetenv) __PROTO__((const char*)); char *(*shsetenv) __PROTO__((const char*)); int invariant; } Shbltin_t; #if defined(SH_VERSION) || defined(_SH_PRIVATE) # undef Shell_t # undef Namval_t #else # define sh_run(c, ac, av) ((c)?(*((Shbltin_t*)(c))->shrun)(ac,av):-1) # define sh_system(c,str) ((c)?(*((Shbltin_t*)(c))->shtrap)(str,0):system(str)) # define sh_exit(c,n) ((c)?(*((Shbltin_t*)(c))->shexit)(n):exit(n)) # define sh_checksig(c) ((c) && ((Shbltin_t*)(c))->sigset) # if defined(SFIO_VERSION) || defined(_AST_H) # define LIB_INIT(c) # else # define LIB_INIT(c) ((c) && (((Shbltin_t*)(c))->nosfio = 1)) # endif # ifndef _CMD_H # define cmdinit(ac,av,c,cat,flg) do { if((ac)<=0) return(0); \ (((Shbltin_t*)(c))->notify = ((flg)&ERROR_NOTIFY)?1:0);} while(0) # endif #endif #if _BLD_ast && defined(__EXPORT__) #undef __MANGLE__ #define __MANGLE__ __LINKAGE__ __EXPORT__ #endif extern __MANGLE__ int astintercept __PROTO__((Shbltin_t*, int)); #undef __MANGLE__ #define __MANGLE__ __LINKAGE__ #endif