1c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* $OpenBSD: sh.h,v 1.31 2012/09/10 01:25:30 tedu Exp $ */ 25155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* $OpenBSD: shf.h,v 1.6 2005/12/11 18:53:51 deraadt Exp $ */ 3c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* $OpenBSD: table.h,v 1.8 2012/02/19 07:52:30 otto Exp $ */ 45155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* $OpenBSD: tree.h,v 1.10 2005/03/28 21:28:22 deraadt Exp $ */ 55155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* $OpenBSD: expand.h,v 1.6 2005/03/30 17:16:37 deraadt Exp $ */ 6c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* $OpenBSD: lex.h,v 1.12 2013/01/20 14:47:46 stsp Exp $ */ 7c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* $OpenBSD: proto.h,v 1.34 2012/06/27 07:17:19 otto Exp $ */ 85155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* $OpenBSD: c_test.h,v 1.4 2004/12/20 11:34:26 otto Exp $ */ 95155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* $OpenBSD: tty.h,v 1.5 2004/12/20 11:34:26 otto Exp $ */ 105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/*- 12c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 13c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * 2011, 2012, 2013 145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * Thorsten Glaser <tg@mirbsd.org> 155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * 165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * Provided that these terms and disclaimer and all copyright notices 175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * are retained or reproduced in an accompanying document, permission 1803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * is granted to deal in this work without restriction, including un‐ 195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * limited rights to use, publicly perform, distribute, sell, modify, 205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * merge, give away, or sublicence. 215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * 2203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * This work is provided “AS IS” and WITHOUT WARRANTY of any kind, to 235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * the utmost extent permitted by applicable law, neither express nor 245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * implied; without malicious intent or gross negligence. In no event 255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * may a licensor, author or contributor be held liable for indirect, 265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * direct, other damage, loss, or other issues arising in any way out 275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * of dealing in the work, even if advised of the possibility of such 285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * damage or existence of a defect, except proven that it results out 2903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * of said person’s immediate fault when using the work as intended. 305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef __dietlibc__ 335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* XXX imake style */ 3403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define _BSD_SOURCE /* live, BSD, live❣ */ 355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_SYS_PARAM_H 385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/param.h> 395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/types.h> 41c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if HAVE_BOTH_TIME_H 425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/time.h> 43c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#include <time.h> 44c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#elif HAVE_SYS_TIME_H 45c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#include <sys/time.h> 46c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#elif HAVE_TIME_H 47c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#include <time.h> 48c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/ioctl.h> 505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_SYS_SYSMACROS_H 515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/sysmacros.h> 525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_SYS_MKDEV_H 545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/mkdev.h> 555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_SYS_MMAN_H 575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/mman.h> 585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 59c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if HAVE_SYS_RESOURCE_H 605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/resource.h> 61c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/stat.h> 635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <sys/wait.h> 645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <dirent.h> 655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <errno.h> 665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <fcntl.h> 675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_LIBGEN_H 685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <libgen.h> 695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_LIBUTIL_H 715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <libutil.h> 725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <limits.h> 745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_PATHS_H 755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <paths.h> 765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <pwd.h> 785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <setjmp.h> 795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <signal.h> 805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <stdarg.h> 815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <stddef.h> 825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_STDINT_H 835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <stdint.h> 845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <stdio.h> 865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <stdlib.h> 875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <string.h> 885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_STRINGS_H 895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <strings.h> 905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 91c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if HAVE_TERMIOS_H 925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <termios.h> 93c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 94c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* shudder… */ 95c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#include <termio.h> 96c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 97c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef _ISC_UNIX 98c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* XXX imake style */ 99c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#include <sys/sioctl.h> 100c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 1015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_ULIMIT_H 1025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <ulimit.h> 1035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <unistd.h> 1055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_VALUES_H 1065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include <values.h> 1075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __attribute__ 1105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_ATTRIBUTE_BOUNDED 11103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define MKSH_A_BOUNDED(x,y,z) __attribute__((__bounded__ (x, y, z))) 1125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 1135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_A_BOUNDED(x,y,z) /* nothing */ 1145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_ATTRIBUTE_FORMAT 11603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define MKSH_A_FORMAT(x,y,z) __attribute__((__format__ (x, y, z))) 1175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 1185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_A_FORMAT(x,y,z) /* nothing */ 1195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_ATTRIBUTE_NORETURN 12103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define MKSH_A_NORETURN __attribute__((__noreturn__)) 1225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 1235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_A_NORETURN /* nothing */ 1245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_ATTRIBUTE_UNUSED 12603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define MKSH_A_UNUSED __attribute__((__unused__)) 1275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 1285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_A_UNUSED /* nothing */ 1295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_ATTRIBUTE_USED 13103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define MKSH_A_USED __attribute__((__used__)) 1325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 1335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_A_USED /* nothing */ 1345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if defined(MirBSD) && (MirBSD >= 0x09A1) && \ 1375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru defined(__ELF__) && defined(__GNUC__) && \ 1385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru !defined(__llvm__) && !defined(__NWCC__) 1395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 1405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * We got usable __IDSTRING __COPYRIGHT __RCSID __SCCSID macros 1415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * which work for all cases; no need to redefine them using the 1425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * "portable" macros from below when we might have the "better" 1435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * gcc+ELF specific macros or other system dependent ones. 1445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 1455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 1465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __IDSTRING 1475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __IDSTRING_CONCAT 1485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __IDSTRING_EXPAND 1495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __COPYRIGHT 1505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __RCSID 1515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef __SCCSID 1525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define __IDSTRING_CONCAT(l,p) __LINTED__ ## l ## _ ## p 1535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define __IDSTRING_EXPAND(l,p) __IDSTRING_CONCAT(l,p) 15403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#ifdef MKSH_DONT_EMIT_IDSTRING 15503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define __IDSTRING(prefix, string) /* nothing */ 15603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#else 1575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define __IDSTRING(prefix, string) \ 1585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru static const char __IDSTRING_EXPAND(__LINE__,prefix) [] \ 1595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru MKSH_A_USED = "@(""#)" #prefix ": " string 16003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 1615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define __COPYRIGHT(x) __IDSTRING(copyright,x) 1625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define __RCSID(x) __IDSTRING(rcsid,x) 1635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define __SCCSID(x) __IDSTRING(sccsid,x) 1645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef EXTERN 167c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser__RCSID("$MirOS: src/bin/mksh/sh.h,v 1.639 2013/02/19 18:45:22 tg Exp $"); 1685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 169c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_VERSION "R43 2013/02/19" 1705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 171c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* arithmetic types: C implementation */ 172c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_CAN_INTTYPES 173c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_CAN_UCBINTS 174c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef signed int int32_t; 175c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef unsigned int uint32_t; 176c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 177c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef u_int32_t uint32_t; 178c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 179c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 1805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 181c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* arithmetic types: shell arithmetics */ 182c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_LEGACY_MODE 183c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* 184c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * POSIX demands these to be the C environment's long type 185c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser */ 186c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef long mksh_ari_t; 187c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef unsigned long mksh_uari_t; 188c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 189c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* 190c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * These types are exactly 32 bit wide; signed and unsigned 191c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * integer wraparound, even across division and modulo, for 192c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * any shell code using them, is guaranteed. 193c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser */ 194c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef int32_t mksh_ari_t; 195c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef uint32_t mksh_uari_t; 196c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 1975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 198c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* boolean type (no <stdbool.h> deliberately) */ 199c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef unsigned char mksh_bool; 200c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef bool 201c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* false MUST equal the same 0 as written by static storage initialisation */ 202c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef false 203c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef true 204c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* access macros for boolean type */ 205c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define bool mksh_bool 206c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* values must have identity mapping between mksh_bool and short */ 207c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define false 0 208c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define true 1 209c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* make any-type into bool or short */ 210c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define tobool(cond) ((cond) ? true : false) 2115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 212c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* char (octet) type: C implementation */ 213c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_CAN_INT8TYPE 214c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_CAN_UCBINT8 215c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef unsigned char uint8_t; 216c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 217c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef u_int8_t uint8_t; 2185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 219c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 220c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 221c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* other standard types */ 2225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if !HAVE_RLIM_T 224c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef unsigned long rlim_t; 2255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if !HAVE_SIG_T 2285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef sig_t 2295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef void (*sig_t)(int); 2305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 232c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_TYPEDEF_SIG_ATOMIC_T 233c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef MKSH_TYPEDEF_SIG_ATOMIC_T sig_atomic_t; 2345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 236c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_TYPEDEF_SSIZE_T 237c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef MKSH_TYPEDEF_SSIZE_T ssize_t; 2385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 239c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 240c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* un-do vendor damage */ 241c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 242c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef BAD /* AIX defines that somewhere */ 243c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef PRINT /* LynxOS defines that somewhere */ 244c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef flock /* SCO UnixWare defines that to flock64 but ENOENT */ 245c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 246c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 247c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef MKSH_INCLUDES_ONLY 248c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 249c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* extra types */ 250c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 251c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_GETRUSAGE 252c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef rusage 253c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef RUSAGE_SELF 254c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef RUSAGE_CHILDREN 255c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define rusage mksh_rusage 256c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define RUSAGE_SELF 0 257c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define RUSAGE_CHILDREN -1 258c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 259c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserstruct rusage { 260c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser struct timeval ru_utime; 261c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser struct timeval ru_stime; 262c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser}; 2635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* extra macros */ 2665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef timerclear 2685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define timerclear(tvp) \ 2695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru do { \ 2705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (tvp)->tv_sec = (tvp)->tv_usec = 0; \ 2715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } while (/* CONSTCOND */ 0) 2725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef timeradd 2745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define timeradd(tvp, uvp, vvp) \ 2755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru do { \ 2765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec; \ 2775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec; \ 2785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru if ((vvp)->tv_usec >= 1000000) { \ 2795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_sec++; \ 2805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_usec -= 1000000; \ 2815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } \ 2825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } while (/* CONSTCOND */ 0) 2835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef timersub 2855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define timersub(tvp, uvp, vvp) \ 2865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru do { \ 2875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec; \ 2885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec; \ 2895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru if ((vvp)->tv_usec < 0) { \ 2905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_sec--; \ 2915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vvp)->tv_usec += 1000000; \ 2925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } \ 2935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } while (/* CONSTCOND */ 0) 2945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 2955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_isdigit(c) (((c) >= '0') && ((c) <= '9')) 2975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_islower(c) (((c) >= 'a') && ((c) <= 'z')) 2985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_isupper(c) (((c) >= 'A') && ((c) <= 'Z')) 2995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_tolower(c) (((c) >= 'A') && ((c) <= 'Z') ? (c) - 'A' + 'a' : (c)) 3005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_toupper(c) (((c) >= 'a') && ((c) <= 'z') ? (c) - 'a' + 'A' : (c)) 3015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_isdash(s) (((s) != NULL) && ((s)[0] == '-') && ((s)[1] == '\0')) 3025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_isspace(c) ((((c) >= 0x09) && ((c) <= 0x0D)) || ((c) == 0x20)) 303c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define ksh_min(x,y) ((x) < (y) ? (x) : (y)) 304c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define ksh_max(x,y) ((x) > (y) ? (x) : (y)) 3055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 306c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH__NO_PATH_MAX 3075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef PATH_MAX 3085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 3095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef PATH_MAX 3105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define PATH_MAX 1024 3115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef SIZE_MAX 3145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef SIZE_T_MAX 3155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SIZE_MAX SIZE_T_MAX 3165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 3175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SIZE_MAX ((size_t)-1) 3185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef S_ISLNK 3215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define S_ISLNK(m) ((m & 0170000) == 0120000) 3225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef S_ISSOCK 3245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define S_ISSOCK(m) ((m & 0170000) == 0140000) 3255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 32603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#if !defined(S_ISCDF) && defined(S_CDF) 32703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define S_ISCDF(m) (S_ISDIR(m) && ((m) & S_CDF)) 32803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 3295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef DEFFILEMODE 3305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DEFFILEMODE (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH) 3315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 3335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef NSIG 3345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if defined(_NSIG) 3355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define NSIG _NSIG 3365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#elif defined(SIGMAX) 3375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define NSIG (SIGMAX+1) 338c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#elif defined(_SIGMAX) 339c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define NSIG (_SIGMAX+1) 3405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 3435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 3445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* OS-dependent additions (functions, variables, by OS) */ 3455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 3465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if !HAVE_FLOCK_DECL 3475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern int flock(int, int); 3485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 350c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_GETTIMEOFDAY 351c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_TIME(tv) do { \ 352c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (tv).tv_usec = 0; \ 353c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (tv).tv_sec = time(NULL); \ 354c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser} while (/* CONSTCOND */ 0) 355c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 356c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_TIME(tv) gettimeofday(&(tv), NULL) 357c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 358c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 3595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if !HAVE_GETRUSAGE 3605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern int getrusage(int, struct rusage *); 3615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 363c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_MEMMOVE 364c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* we assume either memmove or bcopy exist, at the moment */ 365c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define memmove(dst, src, len) bcopy((src), (dst), (len)) 3665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 368c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !HAVE_REVOKE_DECL 369c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserextern int revoke(const char *); 3705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 372c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(DEBUG) || !HAVE_STRERROR 373c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define strerror /* poisoned */ dontuse_strerror 374c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define cstrerror /* replaced */ cstrerror 375c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserextern const char *cstrerror(int); 376c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 377c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define cstrerror(errnum) ((const char *)strerror(errnum)) 3785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 3805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if !HAVE_STRLCPY 3815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querusize_t strlcpy(char *, const char *, size_t); 3825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 3845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef __INTERIX 3855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* XXX imake style */ 3865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define makedev mkdev 3875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern int __cdecl seteuid(uid_t); 3885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern int __cdecl setegid(gid_t); 3895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 3905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 391c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(__COHERENT__) 392c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef O_ACCMODE 393c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* this need not work everywhere, take care */ 394c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define O_ACCMODE (O_RDONLY | O_WRONLY | O_RDWR) 395c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 396c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 397c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 398c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH__NO_SYMLINK 399c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef S_ISLNK 400c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define S_ISLNK(m) (/* CONSTCOND */ 0) 401c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_lstat stat 402c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 403c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_lstat lstat 404c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 405c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 406c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if HAVE_TERMIOS_H 407c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_ttyst struct termios 408c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_tcget(fd,st) tcgetattr((fd), (st)) 409c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_tcset(fd,st) tcsetattr((fd), TCSADRAIN, (st)) 410c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 411c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_ttyst struct termio 412c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_tcget(fd,st) ioctl((fd), TCGETA, (st)) 413c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mksh_tcset(fd,st) ioctl((fd), TCSETAW, (st)) 414c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 4155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 416c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* remove redundancies */ 417c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 418c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(MirBSD) && (MirBSD >= 0x08A8) && !defined(MKSH_OPTSTATIC) 4195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_mirbsd_wcwidth 4205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define utf_wcwidth(i) wcwidth((__WCHAR_TYPE__)i) 4215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern int wcwidth(__WCHAR_TYPE__); 4225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 4235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 4245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 4255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* some useful #defines */ 4265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef EXTERN 42703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra# define E_INIT(i) = i 4285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 42903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra# define E_INIT(i) 4305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru# define EXTERN extern 4315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru# define EXTERN_DEFINED 4325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 4335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 43403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* define bit in flag */ 43503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define BIT(i) (1 << (i)) 4365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define NELEM(a) (sizeof(a) / sizeof((a)[0])) 4375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 43803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* 43903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * Make MAGIC a char that might be printed to make bugs more obvious, but 4405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * not a char that is used often. Also, can't use the high bit as it causes 441c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * portability problems (calling strchr(x, 0x80 | 'x') is error prone). 4425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 4435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MAGIC (7) /* prefix for *?[!{,} during expand */ 4445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ISMAGIC(c) ((unsigned char)(c) == MAGIC) 4455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 4465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LINE 4096 /* input line size */ 4475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 4485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN const char *safe_prompt; /* safe prompt if PS1 substitution fails */ 449c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 450c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_LEGACY_MODE 451c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define KSH_VERSIONNAME "LEGACY" 452c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 453c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define KSH_VERSIONNAME "MIRBSD" 454c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 455c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN const char initvsn[] E_INIT("KSH_VERSION=@(#)" KSH_VERSIONNAME \ 456c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser " KSH " MKSH_VERSION); 4575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define KSH_VERSION (initvsn + /* "KSH_VERSION=@(#)" */ 16) 4585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 45903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char digits_uc[] E_INIT("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"); 46003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char digits_lc[] E_INIT("0123456789abcdefghijklmnopqrstuvwxyz"); 4615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 4625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 4635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * Evil hack for const correctness due to API brokenness 4645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 4655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruunion mksh_cchack { 4665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *rw; 4675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *ro; 4685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 4695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruunion mksh_ccphack { 4705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char **rw; 4715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char **ro; 4725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 4735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 4745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* for const debugging */ 4755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if defined(DEBUG) && defined(__GNUC__) && !defined(__ICC) && \ 4765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru !defined(__INTEL_COMPILER) && !defined(__SUNPRO_C) 4775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *ucstrchr(char *, int); 4785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *ucstrstr(char *, const char *); 4795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef strchr 4805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define strchr ucstrchr 4815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define strstr ucstrstr 4825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define cstrchr(s,c) ({ \ 4835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union mksh_cchack in, out; \ 4845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru \ 4855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru in.ro = (s); \ 4865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru out.rw = ucstrchr(in.rw, (c)); \ 4875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (out.ro); \ 4885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}) 4895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define cstrstr(b,l) ({ \ 4905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union mksh_cchack in, out; \ 4915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru \ 4925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru in.ro = (b); \ 4935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru out.rw = ucstrstr(in.rw, (l)); \ 4945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (out.ro); \ 4955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}) 4965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define vstrchr(s,c) (cstrchr((s), (c)) != NULL) 4975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define vstrstr(b,l) (cstrstr((b), (l)) != NULL) 4985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else /* !DEBUG, !gcc */ 4995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define cstrchr(s,c) ((const char *)strchr((s), (c))) 5005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define cstrstr(s,c) ((const char *)strstr((s), (c))) 5015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define vstrchr(s,c) (strchr((s), (c)) != NULL) 5025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define vstrstr(b,l) (strstr((b), (l)) != NULL) 503c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 504c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 505c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(DEBUG) || defined(__COVERITY__) 506c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mkssert(e) do { if (!(e)) exit(255); } while (/* CONSTCOND */ 0) 507c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef DEBUG_LEAKS 508c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define DEBUG_LEAKS 509c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 510c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 511c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define mkssert(e) do { } while (/* CONSTCOND */ 0) 512c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 513c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 514c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if (!defined(MKSH_BUILDMAKEFILE4BSD) && !defined(MKSH_BUILDSH)) || (MKSH_BUILD_R != 431) 515c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#error Must run Build.sh to compile this. 516c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserint 517c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserim_sorry_dave(void) 518c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser{ 519c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* I’m sorry, Dave. I’m afraid I can’t do that. */ 520c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser return (thiswillneverbedefinedIhope()); 521c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser} 5225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 5245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* use this ipv strchr(s, 0) but no side effects in s! */ 5255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define strnul(s) ((s) + strlen(s)) 5265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 5275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define utf_ptradjx(src, dst) do { \ 5285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (dst) = (src) + utf_ptradj(src); \ 5295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 5305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 531c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(MKSH_SMALL) && !defined(MKSH_SMALL_BUT_FAST) 532c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define strdupx(d, s, ap) do { \ 533c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (d) = strdup_i((s), (ap)); \ 5345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 535c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define strndupx(d, s, n, ap) do { \ 536c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (d) = strndup_i((s), (n), (ap)); \ 5375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 5385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 5395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* be careful to evaluate arguments only once! */ 5405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define strdupx(d, s, ap) do { \ 5415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *strdup_src = (s); \ 5425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *strdup_dst = NULL; \ 5435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru \ 5445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru if (strdup_src != NULL) { \ 5455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru size_t strdup_len = strlen(strdup_src) + 1; \ 5465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru strdup_dst = alloc(strdup_len, (ap)); \ 5475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru memcpy(strdup_dst, strdup_src, strdup_len); \ 5485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } \ 5495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (d) = strdup_dst; \ 5505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 5515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define strndupx(d, s, n, ap) do { \ 5525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *strdup_src = (s); \ 5535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *strdup_dst = NULL; \ 5545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru \ 5555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru if (strdup_src != NULL) { \ 5565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru size_t strndup_len = (n); \ 5575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru strdup_dst = alloc(strndup_len + 1, (ap)); \ 5585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru memcpy(strdup_dst, strdup_src, strndup_len); \ 5595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru strdup_dst[strndup_len] = '\0'; \ 5605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } \ 5615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (d) = strdup_dst; \ 5625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 5635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 565c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_LEGACY_MODE 566c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef MKSH_NO_CMDLINE_EDITING 567c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_NO_CMDLINE_EDITING /* defined */ 568c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 569c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef MKSH_CONSERVATIVE_FDS 570c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_CONSERVATIVE_FDS /* defined */ 571c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 572c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#undef MKSH_S_NOVI 573c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_S_NOVI 1 5745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 5765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef MKSH_SMALL 5775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_CONSERVATIVE_FDS 5785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_CONSERVATIVE_FDS /* defined */ 5795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_NOPWNAM 5815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_NOPWNAM /* defined */ 5825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_S_NOVI 5845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_S_NOVI 1 5855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 5885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_S_NOVI 5895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MKSH_S_NOVI 0 5905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 5915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 59203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#if defined(MKSH_NOPROSPECTOFWORK) && !defined(MKSH_UNEMPLOYED) 59303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define MKSH_UNEMPLOYED 1 59403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 59503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 596c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* these shall be smaller than 100 */ 597c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_CONSERVATIVE_FDS 598c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define NUFILE 32 /* Number of user-accessible files */ 599c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define FDBASE 10 /* First file usable by Shell */ 600c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 601c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define NUFILE 56 /* Number of user-accessible files */ 602c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define FDBASE 24 /* First file usable by Shell */ 603c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 604c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 6055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 6065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * simple grouping allocator 6075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 6085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 60903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 61003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* 0. OS API: where to get memory from and how to free it (grouped) */ 61103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 61203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* malloc(3)/realloc(3) -> free(3) for use by the memory allocator */ 61303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define malloc_osi(sz) malloc(sz) 61403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define realloc_osi(p,sz) realloc((p), (sz)) 61503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define free_osimalloc(p) free(p) 61603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 61703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* malloc(3)/realloc(3) -> free(3) for use by mksh code */ 61803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define malloc_osfunc(sz) malloc(sz) 61903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define realloc_osfunc(p,sz) realloc((p), (sz)) 62003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define free_osfunc(p) free(p) 62103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 62203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#if HAVE_MKNOD 62303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* setmode(3) -> free(3) */ 62403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define free_ossetmode(p) free(p) 62503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 62603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 627c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH__NO_PATH_MAX 62803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* GNU libc: get_current_dir_name(3) -> free(3) */ 62903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define free_gnu_gcdn(p) free(p) 63003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 63103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 63203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 6335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 1. internal structure */ 6345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct lalloc { 6355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct lalloc *next; 6365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 6375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 2. sizes */ 6395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ALLOC_ITEM struct lalloc 6405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ALLOC_SIZE (sizeof(ALLOC_ITEM)) 6415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 3. group structure (only the same for lalloc.c) */ 6435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef struct lalloc Area; 6445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN Area aperm; /* permanent object space */ 6475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define APERM &aperm 6485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ATEMP &e->area 6495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 6515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * flags (the order of these enums MUST match the order in misc.c(options[])) 6525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 6535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruenum sh_flag { 6545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHFLAGS_ENUMS 6555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#include "sh_flags.h" 6565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru FNFLAGS /* (place holder: how many flags are there) */ 6575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 6585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 65903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Flag(f) (shell_flags[(int)(f)]) 6605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define UTFMODE Flag(FUNICODE) 6615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 6635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * parsing & execution environment 664c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * 665c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * note that kshlongjmp MUST NOT be passed 0 as second argument! 6665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 667c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef MKSH_NO_SIGSETJMP 668c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define kshjmp_buf jmp_buf 669c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define kshsetjmp(jbuf) _setjmp(jbuf) 670c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define kshlongjmp _longjmp 671c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#else 672c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define kshjmp_buf sigjmp_buf 673c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define kshsetjmp(jbuf) sigsetjmp((jbuf), 0) 674c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define kshlongjmp siglongjmp 675c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 676c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 677c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserstruct sretrace_info; 678c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserstruct yyrecursive_state; 679c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 680c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN struct sretrace_info *retrace_info E_INIT(NULL); 681c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN int subshell_nesting_type E_INIT(0); 682c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 6835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern struct env { 68403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ALLOC_ITEM alloc_INT; /* internal, do not touch */ 6855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Area area; /* temporary allocation area */ 6865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct env *oenv; /* link to previous environment */ 6875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct block *loc; /* local variables and functions */ 6885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru short *savefd; /* original redirected fds */ 6895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct temp *temps; /* temp files */ 690c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* saved parser recursion state */ 691c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser struct yyrecursive_state *yyrecursive_statep; 692c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser kshjmp_buf jbuf; /* long jump back to env creator */ 693c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser uint8_t type; /* environment type - see below */ 694c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser uint8_t flags; /* EF_* */ 6955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} *e; 6965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 6975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* struct env.type values */ 6985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_NONE 0 /* dummy environment */ 6995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_PARSE 1 /* parsing command # */ 7005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_FUNC 2 /* executing function # */ 7015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_INCL 3 /* including a file via . # */ 7025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_EXEC 4 /* executing command tree */ 7035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_LOOP 5 /* executing for/while # */ 7045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define E_ERRH 6 /* general error handler # */ 705c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define E_GONE 7 /* hidden in child */ 7065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* # indicates env has valid jbuf (see unwind()) */ 7075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 7085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* struct env.flag values */ 7095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EF_BRKCONT_PASS BIT(1) /* set if E_LOOP must pass break/continue on */ 7105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EF_FAKE_SIGDIE BIT(2) /* hack to get info from unwind to quitenv */ 7115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 7125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Do breaks/continues stop at env type e? */ 713c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define STOP_BRKCONT(t) ((t) == E_NONE || (t) == E_PARSE || \ 714c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (t) == E_FUNC || (t) == E_INCL) 7155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Do returns stop at env type e? */ 7165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define STOP_RETURN(t) ((t) == E_FUNC || (t) == E_INCL) 7175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 718c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* values for kshlongjmp(e->jbuf, i) */ 719c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* note that i MUST NOT be zero */ 7205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LRETURN 1 /* return statement */ 7215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LEXIT 2 /* exit statement */ 7225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LERROR 3 /* errorf() called */ 7235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LLEAVE 4 /* untrappable exit/error */ 7245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LINTR 5 /* ^C noticed */ 7255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LBREAK 6 /* break statement */ 7265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LCONTIN 7 /* continue statement */ 7275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LSHELL 8 /* return to interactive shell() */ 7285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LAEXPR 9 /* error in arithmetic expression */ 7295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 73003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* sort of shell global state */ 73103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN pid_t procpid; /* PID of executing process */ 73203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN int exstat; /* exit status */ 73303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN int subst_exstat; /* exit status of last $(..)/`..` */ 73403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN struct tbl *vp_pipest; /* global PIPESTATUS array */ 73503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN short trap_exstat; /* exit status before running a trap */ 73603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN uint8_t trap_nested; /* running nested traps */ 73703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN uint8_t shell_flags[FNFLAGS]; 73803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char *kshname; /* $0 */ 73903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN struct { 74003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra uid_t kshuid_v; /* real UID of shell */ 74103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra uid_t ksheuid_v; /* effective UID of shell */ 74203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra gid_t kshgid_v; /* real GID of shell */ 74303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra gid_t kshegid_v; /* effective GID of shell */ 74403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra pid_t kshpgrp_v; /* process group of shell */ 74503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra pid_t kshppid_v; /* PID of parent of shell */ 74603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra pid_t kshpid_v; /* $$, shell PID */ 74703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} rndsetupstate; 74803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 74903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define kshpid rndsetupstate.kshpid_v 75003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define kshpgrp rndsetupstate.kshpgrp_v 75103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define kshuid rndsetupstate.kshuid_v 75203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define ksheuid rndsetupstate.ksheuid_v 75303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define kshgid rndsetupstate.kshgid_v 75403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define kshegid rndsetupstate.kshegid_v 75503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define kshppid rndsetupstate.kshppid_v 7565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 7575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 7585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* option processing */ 7595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OF_CMDLINE 0x01 /* command line */ 7605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OF_SET 0x02 /* set builtin */ 7615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OF_SPECIAL 0x04 /* a special variable changing */ 7625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OF_INTERNAL 0x08 /* set internally by shell */ 7635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OF_FIRSTTIME 0x10 /* as early as possible, once */ 7645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OF_ANY (OF_CMDLINE | OF_SET | OF_SPECIAL | OF_INTERNAL) 7655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 7665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct shoption { 7675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *name; /* long name of option */ 7685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char c; /* character flag (if any) */ 7695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru unsigned char flags; /* OF_* */ 7705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 7715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern const struct shoption options[]; 7725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 77303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* null value for variable; comparison pointer for unset */ 77403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN char null[] E_INIT(""); 7755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* helpers for string pooling */ 77603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tintovfl[] E_INIT("integer overflow %zu %c %zu prevented"); 77703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Toomem[] E_INIT("can't allocate %lu data bytes"); 77803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#if defined(__GNUC__) 77903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* trust this to have string pooling; -Wformat bitches otherwise */ 78003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Tsynerr "syntax error" 78103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#else 78203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tsynerr[] E_INIT("syntax error"); 78303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 78403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tselect[] E_INIT("select"); 78503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tr_fc_e_dash[] E_INIT("r=fc -e -"); 78603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Tfc_e_dash (Tr_fc_e_dash + 2) /* "fc -e -" */ 78703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Zfc_e_dash 7 /* strlen(Tfc_e_dash) */ 78803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tlocal_typeset[] E_INIT("local=typeset"); 78903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define T_typeset (Tlocal_typeset + 5) /* "=typeset" */ 79003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Ttypeset (Tlocal_typeset + 6) /* "typeset" */ 79103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tpalias[] E_INIT("+alias"); 79203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Talias (Tpalias + 1) /* "alias" */ 79303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tpunalias[] E_INIT("+unalias"); 79403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Tunalias (Tpunalias + 1) /* "unalias" */ 79503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tsgset[] E_INIT("*=set"); 79603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Tset (Tsgset + 2) /* "set" */ 797c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN const char Tsgunset[] E_INIT("*=unset"); 798c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define Tunset (Tsgunset + 2) /* "unset" */ 799c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN const char Tsgexport[] E_INIT("*=export"); 800c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define Texport (Tsgexport + 2) /* "export" */ 801c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN const char Tsgreadonly[] E_INIT("*=readonly"); 802c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define Treadonly (Tsgreadonly + 2) /* "readonly" */ 80303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char Tgbuiltin[] E_INIT("=builtin"); 80403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Tbuiltin (Tgbuiltin + 1) /* "builtin" */ 80503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN const char T_function[] E_INIT(" function"); 80603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define Tfunction (T_function + 1) /* "function" */ 807c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN const char TC_LEX1[] E_INIT("|&;<>() \t\n"); 808c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define TC_IFSWS (TC_LEX1 + 7) /* space tab newline */ 809c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 810c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef uint8_t Temp_type; 811c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* expanded heredoc */ 812c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define TT_HEREDOC_EXP 0 813c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* temporary file used for history editing (fc -e) */ 814c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define TT_HIST_EDIT 1 815c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* temporary file used during in-situ command substitution */ 816c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define TT_FUNSUB 2 8175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* temp/heredoc files. The file is removed when the struct is freed. */ 8195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct temp { 8205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct temp *next; 8215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct shf *shf; 822c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* pid of process parsed here-doc */ 823c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser pid_t pid; 8245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Temp_type type; 825c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* actually longer: name (variable length) */ 826c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser char tffn[3]; 8275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 8285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 8305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * stdio and our IO routines 8315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 8325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shl_spare (&shf_iob[0]) /* for c_read()/c_print() */ 8345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shl_stdout (&shf_iob[1]) 8355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shl_out (&shf_iob[2]) 836c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef DF 837c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define shl_dbg (&shf_iob[3]) /* for DF() */ 838c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 83903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN bool shl_stdout_ok; 8405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 8425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * trap handlers 8435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 8445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef struct trap { 8455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *name; /* short name */ 8465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *mess; /* descriptive name */ 8475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *trap; /* trap command */ 8485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru sig_t cursig; /* current handler (valid if TF_ORIG_* set) */ 8495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru sig_t shtrap; /* shell signal handler */ 8505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int signal; /* signal number */ 8515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int flags; /* TF_* */ 8525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru volatile sig_atomic_t set; /* trap pending */ 8535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} Trap; 8545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* values for Trap.flags */ 8565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_SHELL_USES BIT(0) /* shell uses signal, user can't change */ 8575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_USER_SET BIT(1) /* user has (tried to) set trap */ 8585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_ORIG_IGN BIT(2) /* original action was SIG_IGN */ 8595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_ORIG_DFL BIT(3) /* original action was SIG_DFL */ 8605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_EXEC_IGN BIT(4) /* restore SIG_IGN just before exec */ 8615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_EXEC_DFL BIT(5) /* restore SIG_DFL just before exec */ 8625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_DFL_INTR BIT(6) /* when received, default action is LINTR */ 8635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_TTY_INTR BIT(7) /* tty generated signal (see j_waitj) */ 8645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_CHANGED BIT(8) /* used by runtrap() to detect trap changes */ 8655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TF_FATAL BIT(9) /* causes termination if not trapped */ 8665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* values for setsig()/setexecsig() flags argument */ 8685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_RESTORE_MASK 0x3 /* how to restore a signal before an exec() */ 8695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_RESTORE_CURR 0 /* leave current handler in place */ 8705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_RESTORE_ORIG 1 /* restore original handler */ 8715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_RESTORE_DFL 2 /* restore to SIG_DFL */ 8725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_RESTORE_IGN 3 /* restore to SIG_IGN */ 8735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_FORCE BIT(3) /* set signal even if original signal ignored */ 8745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_USER BIT(4) /* user is doing the set (ie, trap command) */ 8755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SS_SHTRAP BIT(5) /* trap for internal use (ALRM, CHLD, WINCH) */ 8765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 87703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define ksh_SIGEXIT 0 /* for trap EXIT */ 87803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define ksh_SIGERR NSIG /* for trap ERR */ 8795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN volatile sig_atomic_t trap; /* traps pending? */ 8815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN volatile sig_atomic_t intrsig; /* pending trap interrupts command */ 88203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN volatile sig_atomic_t fatal_trap; /* received a fatal signal */ 8835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern Trap sigtraps[NSIG+1]; 8845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* got_winch = 1 when we need to re-adjust the window size */ 8865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef SIGWINCH 88703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN volatile sig_atomic_t got_winch E_INIT(1); 8885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 8895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define got_winch true 8905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 8915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 8925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 8935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * TMOUT support 8945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 8955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* values for ksh_tmout_state */ 8965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruenum tmout_enum { 8975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TMOUT_EXECUTING = 0, /* executing commands */ 8985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TMOUT_READING, /* waiting for input */ 8995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TMOUT_LEAVING /* have timed out */ 9005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 9015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN unsigned int ksh_tmout; 90203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN enum tmout_enum ksh_tmout_state E_INIT(TMOUT_EXECUTING); 9035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* For "You have stopped jobs" message */ 905c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN bool really_exit; 9065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 9085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * fast character classes 9095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 9105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_ALPHA BIT(0) /* a-z_A-Z */ 9115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_DIGIT BIT(1) /* 0-9 */ 9125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_LEX1 BIT(2) /* \t \n\0|&;<>() */ 9135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_VAR1 BIT(3) /* *@#!$-? */ 9145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_IFSWS BIT(4) /* \t \n (IFS white space) */ 9155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_SUBOP1 BIT(5) /* "=-+?" */ 9165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_QUOTE BIT(6) /* \t\n "#$&'()*;<=>?[\]`| (needing quoting) */ 9175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_IFS BIT(7) /* $IFS */ 9185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define C_SUBOP2 BIT(8) /* "#%" (magic, see below) */ 9195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern unsigned char chtypes[]; 9215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 92203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define ctype(c, t) tobool( ((t) == C_SUBOP2) ? \ 9235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (((c) == '#' || (c) == '%') ? 1 : 0) : \ 92403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (chtypes[(unsigned char)(c)] & (t)) ) 9255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_isalphx(c) ctype((c), C_ALPHA) 9265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ksh_isalnux(c) ctype((c), C_ALPHA | C_DIGIT) 9275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 92803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN int ifs0 E_INIT(' '); /* for "$*" */ 9295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Argument parsing for built-in commands and getopts command */ 9315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Values for Getopt.flags */ 9335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define GF_ERROR BIT(0) /* call errorf() if there is an error */ 9345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define GF_PLUSOPT BIT(1) /* allow +c as an option */ 9355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define GF_NONAME BIT(2) /* don't print argv[0] in errors */ 9365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Values for Getopt.info */ 9385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define GI_MINUS BIT(0) /* an option started with -... */ 9395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define GI_PLUS BIT(1) /* an option started with +... */ 9405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define GI_MINUSMINUS BIT(2) /* arguments were ended with -- */ 9415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 94203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* in case some OS defines these */ 94303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#undef optarg 94403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#undef optind 94503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 9465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef struct { 94703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra const char *optarg; 94803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int optind; 94903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int uoptind; /* what user sees in $OPTIND */ 95003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int flags; /* see GF_* */ 95103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int info; /* see GI_* */ 95203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra unsigned int p; /* 0 or index into argv[optind - 1] */ 95303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char buf[2]; /* for bad option OPTARG value */ 9545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} Getopt; 9555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN Getopt builtin_opt; /* for shell builtin commands */ 9575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN Getopt user_opt; /* parsing state for getopts builtin command */ 9585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* This for co-processes */ 9605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 96103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* something that won't (realisticly) wrap */ 96203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condratypedef int32_t Coproc_id; 96303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 9645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct coproc { 9655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru void *job; /* 0 or job of co-process using input pipe */ 9665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int read; /* pipe from co-process's stdout */ 9675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int readw; /* other side of read (saved temporarily) */ 9685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int write; /* pipe to co-process's stdin */ 9695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int njobs; /* number of live jobs using output pipe */ 9705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Coproc_id id; /* id of current output pipe */ 9715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 9725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct coproc coproc; 9735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 97403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#ifndef MKSH_NOPROSPECTOFWORK 97503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* used in jobs.c and by coprocess stuff in exec.c and select() calls */ 9765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN sigset_t sm_default, sm_sigchld; 97703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 9785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 9795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* name of called builtin function (used by error functions) */ 9805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN const char *builtin_argv0; 98103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* flags of called builtin (SPEC_BI, etc.) */ 98203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN uint32_t builtin_flag; 9835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 98403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* current working directory */ 9855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN char *current_wd; 9865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 98703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* 98803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * Minimum required space to work with on a line - if the prompt leaves 98903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * less space than this on a line, the prompt is truncated. 9905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 9915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MIN_EDIT_SPACE 7 99203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* 99303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * Minimum allowed value for x_cols: 2 for prompt, 3 for " < " at end of line 9945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 9955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MIN_COLS (2 + MIN_EDIT_SPACE + 3) 9965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MIN_LINS 3 99703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN mksh_ari_t x_cols E_INIT(80); /* tty columns */ 998c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN mksh_ari_t x_lins E_INIT(24); /* tty lines */ 9995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 100003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 10015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Determine the location of the system (common) profile */ 100203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 1003c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef MKSH_DEFAULT_PROFILEDIR 100403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#if defined(ANDROID) 1005c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_DEFAULT_PROFILEDIR "/system/etc" 100603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#else 1007c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_DEFAULT_PROFILEDIR "/etc" 1008c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 100903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 101003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 1011c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_SYSTEM_PROFILE MKSH_DEFAULT_PROFILEDIR "/profile" 1012c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define MKSH_SUID_PROFILE MKSH_DEFAULT_PROFILEDIR "/suid_profile" 101303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 10145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Used by v_evaluate() and setstr() to control action when error occurs */ 1016c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define KSH_UNWIND_ERROR 0 /* unwind the stack (kshlongjmp) */ 10175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define KSH_RETURN_ERROR 1 /* return 1/0 for success/failure */ 10185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 10205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * Shell file I/O routines 10215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 10225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 102303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define SHF_BSIZE 512 10245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 102503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define shf_fileno(shf) ((shf)->fd) 10265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shf_setfileno(shf,nfd) ((shf)->fd = (nfd)) 1027c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define shf_getc_i(shf) ((shf)->rnleft > 0 ? \ 10285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (shf)->rnleft--, *(shf)->rp++ : \ 10295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru shf_getchar(shf)) 1030c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define shf_putc_i(c, shf) ((shf)->wnleft == 0 ? \ 10315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru shf_putchar((c), (shf)) : \ 10325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru ((shf)->wnleft--, *(shf)->wp++ = (c))) 10335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shf_eof(shf) ((shf)->flags & SHF_EOF) 10345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shf_error(shf) ((shf)->flags & SHF_ERROR) 103503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define shf_errno(shf) ((shf)->errnosv) 10365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define shf_clearerr(shf) ((shf)->flags &= ~(SHF_EOF | SHF_ERROR)) 10375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Flags passed to shf_*open() */ 10395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_RD 0x0001 10405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_WR 0x0002 10415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_RDWR (SHF_RD|SHF_WR) 10425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_ACCMODE 0x0003 /* mask */ 10435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_GETFL 0x0004 /* use fcntl() to figure RD/WR flags */ 10445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_UNBUF 0x0008 /* unbuffered I/O */ 10455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_CLEXEC 0x0010 /* set close on exec flag */ 10465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_MAPHI 0x0020 /* make fd > FDBASE (and close orig) 10475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * (shf_open() only) */ 10485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_DYNAMIC 0x0040 /* string: increase buffer as needed */ 10495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_INTERRUPT 0x0080 /* EINTR in read/write causes error */ 10505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Flags used internally */ 10515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_STRING 0x0100 /* a string, not a file */ 10525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_ALLOCS 0x0200 /* shf and shf->buf were alloc()ed */ 10535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_ALLOCB 0x0400 /* shf->buf was alloc()ed */ 10545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_ERROR 0x0800 /* read()/write() error */ 10555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_EOF 0x1000 /* read eof (sticky) */ 10565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_READING 0x2000 /* currently reading: rnleft,rp valid */ 10575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SHF_WRITING 0x4000 /* currently writing: wnleft,wp valid */ 10585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct shf { 10615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Area *areap; /* area shf/buf were allocated in */ 10625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru unsigned char *rp; /* read: current position in buffer */ 10635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru unsigned char *wp; /* write: current position in buffer */ 10645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru unsigned char *buf; /* buffer */ 106503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ssize_t bsize; /* actual size of buf */ 106603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ssize_t rbsize; /* size of buffer (1 if SHF_UNBUF) */ 106703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ssize_t rnleft; /* read: how much data left in buffer */ 106803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ssize_t wbsize; /* size of buffer (0 if SHF_UNBUF) */ 106903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ssize_t wnleft; /* write: how much space left in buffer */ 10705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int flags; /* see SHF_* */ 10715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int fd; /* file descriptor */ 107203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int errnosv; /* saved value of errno after error */ 10735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 10745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern struct shf shf_iob[]; 10765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 10775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct table { 10785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Area *areap; /* area to allocate entries */ 10795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct tbl **tbls; /* hashed table items */ 108003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra size_t nfree; /* free table entries */ 108103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra uint8_t tshift; /* table size (2^tshift) */ 10825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 10835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 108403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* table item */ 108503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrastruct tbl { 108603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* Area to allocate from */ 108703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra Area *areap; 108803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* value */ 10895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union { 109003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char *s; /* string */ 109103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra mksh_ari_t i; /* integer */ 109203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra mksh_uari_t u; /* unsigned integer */ 109303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int (*f)(const char **); /* built-in command */ 109403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra struct op *t; /* "function" tree */ 109503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra } val; 10965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union { 10975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct tbl *array; /* array values */ 10985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *fpath; /* temporary path to undef function */ 10995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } u; 11005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union { 110103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int field; /* field with for -L/-R/-Z */ 110203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int errnov; /* CEXEC/CTALIAS */ 11035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } u2; 11045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union { 11055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru uint32_t hval; /* hash(name) */ 11065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru uint32_t index; /* index for an array */ 11075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } ua; 110803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* 110903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * command type (see below), base (if INTEGER), 111003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * offset from val.s of value (if EXPORT) 111103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra */ 111203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int type; 111303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* flags (see below) */ 111403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra uint32_t flag; 111503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 111603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* actually longer: name (variable length) */ 111703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char name[4]; 11185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 11195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1120c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN struct tbl vtemp; 1121c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 11225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* common flag bits */ 11235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ALLOC BIT(0) /* val.s has been allocated */ 11245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DEFINED BIT(1) /* is defined in block */ 11255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ISSET BIT(2) /* has value, vp->val.[si] */ 11265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EXPORT BIT(3) /* exported variable/function */ 11275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TRACE BIT(4) /* var: user flagged, func: execution tracing */ 11285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* (start non-common flags at 8) */ 11295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* flag bits used for variables */ 11305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SPECIAL BIT(8) /* PATH, IFS, SECONDS, etc */ 11315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define INTEGER BIT(9) /* val.i contains integer value */ 11325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define RDONLY BIT(10) /* read-only variable */ 11335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LOCAL BIT(11) /* for local typeset() */ 11345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ARRAY BIT(13) /* array */ 11355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LJUST BIT(14) /* left justify */ 11365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define RJUST BIT(15) /* right justify */ 11375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ZEROFIL BIT(16) /* 0 filled if RJUSTIFY, strip 0s if LJUSTIFY */ 11385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LCASEV BIT(17) /* convert to lower case */ 11395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define UCASEV_AL BIT(18) /* convert to upper case / autoload function */ 11405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define INT_U BIT(19) /* unsigned integer */ 114103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define INT_L BIT(20) /* long integer (no-op but used as magic) */ 11425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define IMPORT BIT(21) /* flag to typeset(): no arrays, must have = */ 11435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LOCAL_COPY BIT(22) /* with LOCAL - copy attrs from existing var */ 11445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EXPRINEVAL BIT(23) /* contents currently being evaluated */ 11455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EXPRLVALUE BIT(24) /* useable as lvalue (temp flag) */ 11465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define AINDEX BIT(25) /* array index >0 = ua.index filled in */ 11475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ASSOC BIT(26) /* ARRAY ? associative : reference */ 11485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* flag bits used for taliases/builtins/aliases/keywords/functions */ 11495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define KEEPASN BIT(8) /* keep command assignments (eg, var=x cmd) */ 11505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FINUSE BIT(9) /* function being executed */ 11515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FDELETE BIT(10) /* function deleted while it was executing */ 11525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FKSH BIT(11) /* function defined with function x (vs x()) */ 11535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SPEC_BI BIT(12) /* a POSIX special builtin */ 11545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define REG_BI BIT(13) /* a POSIX regular builtin */ 115503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* 115603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * Attributes that can be set by the user (used to decide if an unset 115703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * param should be repoted by set/typeset). Does not include ARRAY or 115803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra * LOCAL. 11595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 11605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define USERATTRIB (EXPORT|INTEGER|RDONLY|LJUST|RJUST|ZEROFIL|\ 11615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru LCASEV|UCASEV_AL|INT_U|INT_L) 11625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 11635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define arrayindex(vp) ((unsigned long)((vp)->flag & AINDEX ? \ 11645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (vp)->ua.index : 0)) 11655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 116603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN enum { 116703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra SRF_NOP, 116803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra SRF_ENABLE, 116903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra SRF_DISABLE 117003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} set_refflag E_INIT(SRF_NOP); 117103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 11725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* command types */ 11735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CNONE 0 /* undefined */ 11745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CSHELL 1 /* built-in */ 11755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CFUNC 2 /* function */ 11765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CEXEC 4 /* executable command */ 11775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CALIAS 5 /* alias */ 11785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CKEYWD 6 /* keyword */ 11795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CTALIAS 7 /* tracked alias */ 11805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 11815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Flags for findcom()/comexec() */ 11825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_SPECBI BIT(0) /* special builtin */ 11835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_FUNC BIT(1) /* function builtin */ 11845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_REGBI BIT(2) /* regular builtin */ 11855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_UNREGBI BIT(3) /* un-regular builtin (!special,!regular) */ 11865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_BI (FC_SPECBI|FC_REGBI|FC_UNREGBI) 11875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_PATH BIT(4) /* do path search */ 11885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FC_DEFPATH BIT(5) /* use default path in path search */ 11895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 11905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 11915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define AF_ARGV_ALLOC 0x1 /* argv[] array allocated */ 11925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define AF_ARGS_ALLOCED 0x2 /* argument strings allocated */ 11935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define AI_ARGV(a, i) ((i) == 0 ? (a).argv[0] : (a).argv[(i) - (a).skip]) 119403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define AI_ARGC(a) ((a).ai_argc - (a).skip) 11955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 11965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Argument info. Used for $#, $* for shell, functions, includes, etc. */ 11975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct arg_info { 11985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char **argv; 11995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int flags; /* AF_* */ 120003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int ai_argc; 12015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int skip; /* first arg is argv[0], second is argv[1 + skip] */ 12025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 12035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 12055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * activation record for function blocks 12065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 12075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct block { 12085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Area area; /* area to allocate things */ 12095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char **argv; 12105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *error; /* error handler */ 12115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *exit; /* exit handler */ 12125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct block *next; /* enclosing block */ 12135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct table vars; /* local variables */ 12145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct table funs; /* local functions */ 12155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Getopt getopts_state; 12165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int argc; 12175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int flags; /* see BF_* */ 12185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 12195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Values for struct block.flags */ 12215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define BF_DOGETOPTS BIT(0) /* save/restore getopts state */ 12225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 12245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * Used by ktwalk() and ktnext() routines. 12255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 12265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tstate { 12275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct tbl **next; 12285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru ssize_t left; 12295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 12305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct table taliases; /* tracked aliases */ 12325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct table builtins; /* built-in commands */ 12335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct table aliases; /* aliases */ 12345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct table keywords; /* keywords */ 12355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_NOPWNAM 12365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct table homedirs; /* homedir() cache */ 12375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 12385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct builtin { 12405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *name; 12415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int (*func)(const char **); 12425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 12435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruextern const struct builtin mkshbuiltins[]; 12455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* values for set_prompt() */ 12475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define PS1 0 /* command */ 12485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define PS2 1 /* command continuation */ 12495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN char *path; /* copy of either PATH or def_path */ 12515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN const char *def_path; /* path to use if PATH not set */ 12525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN char *tmpdir; /* TMPDIR value */ 12535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN const char *prompt; 12545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN int cur_prompt; /* PS1 or PS2 */ 12555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN int current_lineno; /* LINENO value */ 12565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define NOBLOCK ((struct op *)NULL) 12585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define NOWORD ((char *)NULL) 12595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define NOWORDS ((char **)NULL) 12605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 12625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * Description of a command or an operation on commands. 12635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 12645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct op { 12655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char **args; /* arguments to a command */ 12665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char **vars; /* variable assignments */ 12675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct ioword **ioact; /* IO actions (eg, < > >>) */ 12685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct op *left, *right; /* descendents */ 12695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *str; /* word for case; identifier for for, 12705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * select, and functions; 12715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * path to execute for TEXEC; 12725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * time hook for TCOM. 12735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 12745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int lineno; /* TCOM/TFUNC: LINENO for this */ 12755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru short type; /* operation type, see below */ 127603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* WARNING: newtp(), tcopy() use evalflags = 0 to clear union */ 127703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra union { 127803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* TCOM: arg expansion eval() flags */ 127903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra short evalflags; 128003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* TFUNC: function x (vs x()) */ 128103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra short ksh_func; 128203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* TPAT: termination character */ 128303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char charflag; 12845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } u; 12855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 12865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 12875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Tree.type values */ 12885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TEOF 0 12895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TCOM 1 /* command */ 12905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TPAREN 2 /* (c-list) */ 12915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TPIPE 3 /* a | b */ 12925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TLIST 4 /* a ; b */ 12935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TOR 5 /* || */ 12945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TAND 6 /* && */ 12955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TBANG 7 /* ! */ 12965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TDBRACKET 8 /* [[ .. ]] */ 12975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TFOR 9 12985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TSELECT 10 12995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TCASE 11 13005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TIF 12 13015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TWHILE 13 13025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TUNTIL 14 13035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TELIF 15 13045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TPAT 16 /* pattern in case */ 13055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TBRACE 17 /* {c-list} */ 13065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TASYNC 18 /* c & */ 13075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TFUNCT 19 /* function name { command; } */ 13085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TTIME 20 /* time pipeline */ 13095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TEXEC 21 /* fork/exec eval'd TCOM */ 13105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TCOPROC 22 /* coprocess |& */ 13115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 13125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 13135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * prefix codes for words in command tree 13145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 13155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EOS 0 /* end of string */ 13165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CHAR 1 /* unquoted character */ 13175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define QCHAR 2 /* quoted character */ 13185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define COMSUB 3 /* $() substitution (0 terminated) */ 13195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define EXPRSUB 4 /* $(()) substitution (0 terminated) */ 13205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OQUOTE 5 /* opening " or ' */ 13215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CQUOTE 6 /* closing " or ' */ 13225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OSUBST 7 /* opening ${ subst (followed by { or X) */ 13235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CSUBST 8 /* closing } of above (followed by } or X) */ 13245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define OPAT 9 /* open pattern: *(, @(, etc. */ 13255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SPAT 10 /* separate pattern: | */ 13265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CPAT 11 /* close pattern: ) */ 13275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ADELIM 12 /* arbitrary delimiter: ${foo:2:3} ${foo/bar/baz} */ 1328c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define FUNSUB 14 /* ${ foo;} substitution (NUL terminated) */ 13295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 13305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 13315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * IO redirection 13325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 13335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct ioword { 133403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int unit; /* unit affected */ 133503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int flag; /* action (below) */ 133603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char *name; /* file name (unused if heredoc) */ 133703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char *delim; /* delimiter for <<,<<- */ 133803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra char *heredoc; /* content of heredoc */ 13395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 13405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 13415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* ioword.flag - type of redirection */ 134203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOTYPE 0xF /* type: bits 0:3 */ 134303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOREAD 0x1 /* < */ 134403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOWRITE 0x2 /* > */ 134503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IORDWR 0x3 /* <>: todo */ 134603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOHERE 0x4 /* << (here file) */ 134703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOCAT 0x5 /* >> */ 134803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IODUP 0x6 /* <&/>& */ 134903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOEVAL BIT(4) /* expand in << */ 135003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOSKIP BIT(5) /* <<-, skip ^\t* */ 135103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOCLOB BIT(6) /* >|, override -o noclobber */ 135203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IORDUP BIT(7) /* x<&y (as opposed to x>&y) */ 135303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IONAMEXP BIT(8) /* name has been expanded */ 135403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOBASH BIT(9) /* &> etc. */ 135503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IOHERESTR BIT(10) /* <<< (here string) */ 135603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define IONDELIM BIT(11) /* null delimiter (<<) */ 13575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 13585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* execute/exchild flags */ 13595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XEXEC BIT(0) /* execute without forking */ 13605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XFORK BIT(1) /* fork before executing */ 13615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XBGND BIT(2) /* command & */ 13625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XPIPEI BIT(3) /* input is pipe */ 13635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XPIPEO BIT(4) /* output is pipe */ 13645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XXCOM BIT(5) /* `...` command */ 13655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XPCLOSE BIT(6) /* exchild: close close_fd in parent */ 13665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XCCLOSE BIT(7) /* exchild: close close_fd in child */ 13675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XERROK BIT(8) /* non-zero exit ok (for set -e) */ 13685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XCOPROC BIT(9) /* starting a co-process */ 13695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XTIME BIT(10) /* timing TCOM command */ 137003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define XPIPEST BIT(11) /* want PIPESTATUS */ 13715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 13725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 13735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * flags to control expansion of words (assumed by t->evalflags to fit 13745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * in a short) 13755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 13765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOBLANK BIT(0) /* perform blank interpretation */ 13775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOGLOB BIT(1) /* expand [?* */ 13785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOPAT BIT(2) /* quote *?[ */ 13795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOTILDE BIT(3) /* normal ~ expansion (first char) */ 13805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DONTRUNCOMMAND BIT(4) /* do not run $(command) things */ 13815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOASNTILDE BIT(5) /* assignment ~ expansion (after =, :) */ 138203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define DOBRACE BIT(6) /* used by expand(): do brace expansion */ 138303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define DOMAGIC BIT(7) /* used by expand(): string contains MAGIC */ 138403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define DOTEMP BIT(8) /* dito: in word part of ${..[%#=?]..} */ 13855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOVACHECK BIT(9) /* var assign check (for typeset, set, etc) */ 13865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DOMARKDIRS BIT(10) /* force markdirs behaviour */ 1387c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !defined(MKSH_SMALL) 1388c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define DOTCOMEXEC BIT(11) /* not an eval flag, used by sh -c hack */ 1389c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 13905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 13915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 13925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * The arguments of [[ .. ]] expressions are kept in t->args[] and flags 13935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * indicating how the arguments have been munged are kept in t->vars[]. 13945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * The contents of t->vars[] are stuffed strings (so they can be treated 13955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * like all other t->vars[]) in which the second character is the one that 13965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * is examined. The DB_* defines are the values for these second characters. 13975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 13985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DB_NORM 1 /* normal argument */ 13995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DB_OR 2 /* || -> -o conversion */ 14005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DB_AND 3 /* && -> -a conversion */ 14015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DB_BE 4 /* an inserted -BE */ 14025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DB_PAT 5 /* a pattern argument */ 14035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 140403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define X_EXTRA 20 /* this many extra bytes in X string */ 14055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef struct XString { 14075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *end, *beg; /* end, begin of string */ 14085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru size_t len; /* length */ 14095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Area *areap; /* area to allocate/free from */ 14105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} XString; 14115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef char *XStringP; 14135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* initialise expandable string */ 14155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XinitN(xs, length, area) do { \ 14165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (xs).len = (length); \ 14175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (xs).areap = (area); \ 14185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (xs).beg = alloc((xs).len + X_EXTRA, (xs).areap); \ 14195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (xs).end = (xs).beg + (xs).len; \ 14205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 14215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xinit(xs, xp, length, area) do { \ 14225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru XinitN((xs), (length), (area)); \ 14235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru (xp) = (xs).beg; \ 14245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 14255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* stuff char into string */ 14275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xput(xs, xp, c) (*xp++ = (c)) 14285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* check if there are at least n bytes left */ 14305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XcheckN(xs, xp, n) do { \ 143103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ssize_t more = ((xp) + (n)) - (xs).end; \ 14325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru if (more > 0) \ 1433c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (xp) = Xcheck_grow(&(xs), (xp), more); \ 14345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 14355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* check for overflow, expand string */ 14375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xcheck(xs, xp) XcheckN((xs), (xp), 1) 14385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* free string */ 14405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xfree(xs, xp) afree((xs).beg, (xs).areap) 14415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* close, return string */ 14435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xclose(xs, xp) aresize((xs).beg, (xp) - (xs).beg, (xs).areap) 14445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* begin of string */ 14465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xstring(xs, xp) ((xs).beg) 14475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xnleft(xs, xp) ((xs).end - (xp)) /* may be less than 0 */ 14495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xlength(xs, xp) ((xp) - (xs).beg) 14505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xsize(xs, xp) ((xs).end - (xs).beg) 14515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xsavepos(xs, xp) ((xp) - (xs).beg) 14525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define Xrestpos(xs, xp, n) ((xs).beg + (n)) 14535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1454c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserchar *Xcheck_grow(XString *, const char *, size_t); 14555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* 14575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * expandable vector of generic pointers 14585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru */ 14595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1460c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasertypedef struct { 1461c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* begin of allocated area */ 1462c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser void **beg; 1463c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* currently used number of entries */ 1464c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser size_t len; 1465c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser /* allocated number of entries */ 1466c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser size_t siz; 14675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} XPtrV; 14685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1469c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define XPinit(x, n) do { \ 1470c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (x).siz = (n); \ 1471c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (x).len = 0; \ 1472c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (x).beg = alloc2((x).siz, sizeof(void *), ATEMP); \ 1473c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser} while (/* CONSTCOND */ 0) \ 1474c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 1475c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define XPput(x, p) do { \ 1476c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser if ((x).len == (x).siz) { \ 1477c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (x).beg = aresize2((x).beg, (x).siz, \ 1478c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 2 * sizeof(void *), ATEMP); \ 1479c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (x).siz <<= 1; \ 14805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } \ 1481c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (x).beg[(x).len++] = (p); \ 14825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} while (/* CONSTCOND */ 0) 14835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XPptrv(x) ((x).beg) 1485c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define XPsize(x) ((x).len) 148603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define XPclose(x) aresize2((x).beg, XPsize(x), sizeof(void *), ATEMP) 14875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define XPfree(x) afree((x).beg, ATEMP) 14885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1489c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* 1490c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser * Lexer internals 1491c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser */ 14925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 14935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef struct source Source; 14945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct source { 14955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *str; /* input pointer */ 14965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *start; /* start of current buffer */ 14975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union { 14985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char **strv; /* string [] */ 14995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct shf *shf; /* shell file */ 15005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct tbl *tblp; /* alias (SF_HASALIAS) */ 15015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *freeme; /* also for SREREAD */ 15025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } u; 15035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *file; /* input file name */ 15045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int type; /* input type */ 15055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int line; /* line number */ 15065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int errline; /* line the error occurred on (0 if not set) */ 15075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int flags; /* SF_* */ 15085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Area *areap; 15095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Source *next; /* stacked source */ 15105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru XString xs; /* input buffer */ 15115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char ugbuf[2]; /* buffer for ungetsc() (SREREAD) and 15125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru * alias (SALIAS) */ 15135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 15145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 15155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Source.type values */ 15165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SEOF 0 /* input EOF */ 15175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SFILE 1 /* file input */ 15185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SSTDIN 2 /* read stdin */ 15195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SSTRING 3 /* string */ 15205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SWSTR 4 /* string without \n */ 15215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SWORDS 5 /* string[] */ 15225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SWORDSEP 6 /* string[] separator */ 15235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SALIAS 7 /* alias expansion */ 15245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SREREAD 8 /* read ahead to be re-scanned */ 1525c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define SSTRINGCMDLINE 9 /* string from "mksh -c ..." */ 15265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 15275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Source.flags values */ 15285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SF_ECHO BIT(0) /* echo input to shlout */ 15295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SF_ALIAS BIT(1) /* faking space at end of alias */ 15305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SF_ALIASEND BIT(2) /* faking space at end of alias */ 15315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SF_TTY BIT(3) /* type == SSTDIN & it is a tty */ 153203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define SF_HASALIAS BIT(4) /* u.tblp valid (SALIAS, SEOF) */ 1533c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !defined(MKSH_SMALL) 1534c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define SF_MAYEXEC BIT(5) /* special sh -c optimisation hack */ 1535c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 15365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 15375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef union { 15385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int i; 15395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char *cp; 15405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru char **wp; 15415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct op *o; 15425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru struct ioword *iop; 15435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} YYSTYPE; 15445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 15455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* If something is added here, add it to tokentab[] in syn.c as well */ 15465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LWORD 256 15475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LOGAND 257 /* && */ 15485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LOGOR 258 /* || */ 15495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define BREAK 259 /* ;; */ 15505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define IF 260 15515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define THEN 261 15525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ELSE 262 15535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ELIF 263 15545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FI 264 15555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CASE 265 15565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ESAC 266 15575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FOR 267 15585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define SELECT 268 15595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define WHILE 269 15605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define UNTIL 270 15615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DO 271 15625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DONE 272 15635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define IN 273 15645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define FUNCTION 274 15655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TIME 275 15665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define REDIR 276 15675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define MDPAREN 277 /* (( )) */ 15685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define BANG 278 /* ! */ 15695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define DBRACKET 279 /* [[ .. ]] */ 15705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define COPROC 280 /* |& */ 157103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define BRKEV 281 /* ;| */ 157203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define BRKFT 282 /* ;& */ 15735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define YYERRCODE 300 15745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 15755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* flags to yylex */ 15765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CONTIN BIT(0) /* skip new lines to complete command */ 15775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ONEWORD BIT(1) /* single word for substitute() */ 15785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ALIAS BIT(2) /* recognise alias */ 15795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define KEYWORD BIT(3) /* recognise keywords */ 15805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LETEXPR BIT(4) /* get expression inside (( )) */ 15815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define VARASN BIT(5) /* check for var=word */ 15825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ARRAYVAR BIT(6) /* parse x[1 & 2] as one word */ 15835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ESACONLY BIT(7) /* only accept esac keyword */ 15845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CMDWORD BIT(8) /* parsing simple command (alias related) */ 15855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define HEREDELIM BIT(9) /* parsing <<,<<- delimiter */ 15865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define LQCHAR BIT(10) /* source string contains QCHAR */ 1587c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define HEREDOC BIT(11) /* parsing a here document body */ 15885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 158903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define HERES 10 /* max number of << in line */ 15905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 15915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#undef CTRL 15925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define CTRL(x) ((x) == '?' ? 0x7F : (x) & 0x1F) /* ASCII */ 15935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define UNCTRL(x) ((x) ^ 0x40) /* ASCII */ 15945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1595c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define IDENT 64 1596c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser 15975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN Source *source; /* yyparse/yylex source */ 159803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN YYSTYPE yylval; /* result from yylex */ 159903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN struct ioword *heres[HERES], **herep; 1600c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN char ident[IDENT + 1]; 16015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1602c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN char **history; /* saved commands */ 1603c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN char **histptr; /* last history item */ 1604c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN mksh_ari_t histsize; /* history size */ 16055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 16065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* user and system time of last j_waitjed job */ 16075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruEXTERN struct timeval j_usrtime, j_systime; 16085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 1609c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define notok2mul(max, val, c) (((val) != 0) && ((c) != 0) && \ 1610c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser (((max) / (c)) < (val))) 1611c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define notok2add(max, val, c) ((val) > ((max) - (c))) 1612c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define notoktomul(val, cnst) notok2mul(SIZE_MAX, (val), (cnst)) 1613c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define notoktoadd(val, cnst) notok2add(SIZE_MAX, (val), (cnst)) 161403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define checkoktoadd(val, cnst) do { \ 161503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra if (notoktoadd((val), (cnst))) \ 161603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra internal_errorf(Tintovfl, (size_t)(val), \ 161703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra '+', (size_t)(cnst)); \ 161803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} while (/* CONSTCOND */ 0) 161903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 162003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 1621c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* NZAAT hash based on Bob Jenkins' one-at-a-time hash */ 162203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 162303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* From: src/kern/include/nzat.h,v 1.2 2011/07/18 00:35:40 tg Exp $ */ 162403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 162503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define NZATInit(h) do { \ 162603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) = 0; \ 162703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} while (/* CONSTCOND */ 0) 162803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 162903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define NZATUpdateByte(h,b) do { \ 163003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) += (uint8_t)(b); \ 163103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra ++(h); \ 163203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) += (h) << 10; \ 163303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) ^= (h) >> 6; \ 163403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} while (/* CONSTCOND */ 0) 163503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 163603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define NZATUpdateMem(h,p,z) do { \ 163703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra register const uint8_t *NZATUpdateMem_p; \ 163803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra register size_t NZATUpdateMem_z = (z); \ 163903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra \ 164003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra NZATUpdateMem_p = (const void *)(p); \ 164103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra while (NZATUpdateMem_z--) \ 164203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra NZATUpdateByte((h), *NZATUpdateMem_p++); \ 164303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} while (/* CONSTCOND */ 0) 164403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 164503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define NZATUpdateString(h,s) do { \ 164603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra register const char *NZATUpdateString_s; \ 164703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra register uint8_t NZATUpdateString_c; \ 164803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra \ 164903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra NZATUpdateString_s = (const void *)(s); \ 165003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra while ((NZATUpdateString_c = *NZATUpdateString_s++)) \ 165103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra NZATUpdateByte((h), NZATUpdateString_c); \ 165203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} while (/* CONSTCOND */ 0) 165303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 165403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define NZAATFinish(h) do { \ 165503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) += (h) << 10; \ 165603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) ^= (h) >> 6; \ 165703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) += (h) << 3; \ 165803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) ^= (h) >> 11; \ 165903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra (h) += (h) << 15; \ 166003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra} while (/* CONSTCOND */ 0) 166103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 166203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra 16635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* lalloc.c */ 16645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid ainit(Area *); 16655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid afreeall(Area *); 16665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* these cannot fail and can take NULL (not for ap) */ 166703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define alloc(n, ap) aresize(NULL, (n), (ap)) 166803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define alloc2(m, n, ap) aresize2(NULL, (m), (n), (ap)) 16695155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid *aresize(void *, size_t, Area *); 167003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid *aresize2(void *, size_t, size_t, Area *); 16715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid afree(void *, Area *); /* can take NULL */ 16725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* edit.c */ 1673c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef MKSH_NO_CMDLINE_EDITING 16745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_SMALL 16755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint x_bind(const char *, const char *, bool, bool); 16765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#else 16775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint x_bind(const char *, const char *, bool); 16785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 16795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid x_init(void); 1680c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef DEBUG_LEAKS 1681c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid x_done(void); 1682c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 16835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint x_read(char *, size_t); 1684c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 1685c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid x_mkraw(int, mksh_ttyst *, bool); 16865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* eval.c */ 16875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *substitute(const char *, int); 16885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar **eval(const char **, int); 16895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *evalstr(const char *cp, int); 16905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *evalonestr(const char *cp, int); 16915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *debunk(char *, const char *, size_t); 16925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid expand(const char *, XPtrV *, int); 1693c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserint glob_str(char *, XPtrV *, bool); 1694c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserchar *tilde(char *); 16955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* exec.c */ 16965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint execute(struct op * volatile, volatile int, volatile int * volatile); 16975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shcomexec(const char **); 16985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *findfunc(const char *, uint32_t, bool); 16995155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint define(const char *, struct op *); 170003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraconst char *builtin(const char *, int (*)(const char **)); 17015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *findcom(const char *, int); 170203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid flushcom(bool); 170303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraconst char *search_path(const char *, const char *, int, int *); 1704c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid pr_menu(const char * const *); 1705c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid pr_list(char * const *); 17065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* expr.c */ 17075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint evaluate(const char *, mksh_ari_t *, int, bool); 17085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint v_evaluate(struct tbl *, const char *, volatile int, bool); 17095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* UTF-8 stuff */ 17105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querusize_t utf_mbtowc(unsigned int *, const char *); 17115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querusize_t utf_wctomb(char *, unsigned int); 17125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint utf_widthadj(const char *, const char **); 171303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrasize_t utf_mbswidth(const char *); 17145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruconst char *utf_skipcols(const char *, int); 17155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querusize_t utf_ptradj(const char *); 17165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_mirbsd_wcwidth 17175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint utf_wcwidth(unsigned int); 17185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 171903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint ksh_access(const char *, int); 1720c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserstruct tbl *tempvar(void); 17215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* funcs.c */ 17225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_hash(const char **); 17235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_pwd(const char **); 17245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_print(const char **); 17255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef MKSH_PRINTF_BUILTIN 17265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_printf(const char **); 17275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 17285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_whence(const char **); 17295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_command(const char **); 17305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_typeset(const char **); 17315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_alias(const char **); 17325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_unalias(const char **); 17335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_let(const char **); 17345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_jobs(const char **); 17355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_UNEMPLOYED 17365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_fgbg(const char **); 17375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 17385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_kill(const char **); 17395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid getopts_reset(int); 17405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_getopts(const char **); 1741c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifndef MKSH_NO_CMDLINE_EDITING 17425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_bind(const char **); 1743c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 17445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_shift(const char **); 17455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_umask(const char **); 17465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_dot(const char **); 17475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_wait(const char **); 17485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_read(const char **); 17495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_eval(const char **); 17505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_trap(const char **); 17515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_brkcont(const char **); 17525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_exitreturn(const char **); 17535155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_set(const char **); 17545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_unset(const char **); 17555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_ulimit(const char **); 17565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_times(const char **); 17575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint timex(struct op *, int, volatile int *); 17585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid timex_hook(struct op *, char ** volatile *); 17595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_exec(const char **); 176003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* dummy function (just need pointer value), special case in comexec() */ 176103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define c_builtin shcomexec 17625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_test(const char **); 17635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_MKNOD 17645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_mknod(const char **); 17655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 17665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_realpath(const char **); 17675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_rename(const char **); 176803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint c_cat(const char **); 176903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint c_sleep(const char **); 17705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* histrap.c */ 17715155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid init_histvec(void); 17725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid hist_init(Source *); 17735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_PERSISTENT_HISTORY 17745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid hist_finish(void); 17755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 17765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid histsave(int *, const char *, bool, bool); 17775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if !defined(MKSH_SMALL) && HAVE_PERSISTENT_HISTORY 17785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querubool histsync(void); 17795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 17805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint c_fc(const char **); 1781c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid sethistsize(mksh_ari_t); 17825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#if HAVE_PERSISTENT_HISTORY 17835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid sethistfile(const char *); 17845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 1785c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if !defined(MKSH_NO_CMDLINE_EDITING) && !MKSH_S_NOVI 17865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar **histpos(void); 17875155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint histnum(int); 1788c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 17895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint findhist(int, int, const char *, int); 17905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar **hist_get_newest(bool); 17915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid inittraps(void); 17925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid alarm_init(void); 1793c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserTrap *gettrap(const char *, bool); 17945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid trapsig(int); 17955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid intrcheck(void); 17965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint fatal_trap_check(void); 17975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint trap_pending(void); 17985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid runtraps(int intr); 179903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid runtrap(Trap *, bool); 18005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid cleartraps(void); 18015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid restoresigs(void); 18025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid settrap(Trap *, const char *); 18035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint block_pipe(void); 18045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid restore_pipe(int); 18055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint setsig(Trap *, sig_t, int); 18065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid setexecsig(Trap *, int); 1807c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if HAVE_FLOCK || HAVE_LOCK_FCNTL 1808c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid mksh_lockfd(int); 1809c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid mksh_unlkfd(int); 1810c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 18115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* jobs.c */ 18125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid j_init(void); 18135155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid j_exit(void); 18145155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_UNEMPLOYED 18155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid j_change(void); 18165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 18175155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint exchild(struct op *, int, volatile int *, int); 18185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid startlast(void); 18195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint waitlast(void); 18205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint waitfor(const char *, int *); 18215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint j_kill(const char *, int); 18225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifndef MKSH_UNEMPLOYED 18235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint j_resume(const char *, int); 18245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 18255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint j_jobs(const char *, int, int); 18265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid j_notify(void); 18275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querupid_t j_async(void); 18285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint j_stopped_running(void); 18295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* lex.c */ 18305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint yylex(int); 1831c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid yyskiputf8bom(void); 18325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid yyerror(const char *, ...) 18335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru MKSH_A_NORETURN 183403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 18355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruSource *pushs(int, Area *); 18365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid set_prompt(int, Source *); 18375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid pprompt(const char *, int); 18385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint promptlen(const char *); 18395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* main.c */ 1840c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserint include(const char *, int, const char **, bool); 18415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint command(const char *, int); 1842c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserint shell(Source * volatile, volatile bool); 1843c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser/* argument MUST NOT be 0 */ 18445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid unwind(int) MKSH_A_NORETURN; 18455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid newenv(int); 18465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid quitenv(struct shf *); 18475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid cleanup_parents_env(void); 18485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid cleanup_proc_env(void); 18495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid errorf(const char *, ...) 18505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru MKSH_A_NORETURN 185103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 185203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid errorfx(int, const char *, ...) 185303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_NORETURN 185403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 2, 3); 18555155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid warningf(bool, const char *, ...) 185603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 2, 3); 18575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid bi_errorf(const char *, ...) 185803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 1859c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define errorfz() errorf(NULL) 1860c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define errorfxz(rc) errorfx((rc), NULL) 1861c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define bi_errorfz() bi_errorf(NULL) 18625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid internal_errorf(const char *, ...) 18635155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru MKSH_A_NORETURN 186403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 18655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid internal_warningf(const char *, ...) 186603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 18675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid error_prefix(bool); 18685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid shellf(const char *, ...) 186903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 18705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid shprintf(const char *, ...) 187103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 18725155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint can_seek(int); 18735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid initio(void); 18745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint ksh_dup2(int, int, bool); 18755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querushort savefd(int); 18765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid restfd(int, int); 18775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid openpipe(int *); 18785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid closepipe(int *); 18795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint check_fd(const char *, int, const char **); 18805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid coproc_init(void); 18815155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid coproc_read_close(int); 18825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid coproc_readw_close(int); 18835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid coproc_write_close(int); 18845155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint coproc_getfd(int, const char **); 18855155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid coproc_cleanup(int); 18865155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct temp *maketemp(Area *, Temp_type, struct temp **); 188703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid ktinit(Area *, struct table *, uint8_t); 188803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrastruct tbl *ktscan(struct table *, const char *, uint32_t, struct tbl ***); 188903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra/* table, name (key) to search for, hash(n) */ 189003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define ktsearch(tp, s, h) ktscan((tp), (s), (h), NULL) 18915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *ktenter(struct table *, const char *, uint32_t); 18925155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define ktdelete(p) do { p->flag = 0; } while (/* CONSTCOND */ 0) 18935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid ktwalk(struct tstate *, struct table *); 18945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *ktnext(struct tstate *); 18955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl **ktsort(struct table *); 1896c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#ifdef DF 1897c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid DF(const char *, ...) 1898c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser MKSH_A_FORMAT(__printf__, 1, 2); 1899c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#endif 19005155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* misc.c */ 19015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid setctypes(const char *, int); 19025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid initctypes(void); 19035155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querusize_t option(const char *); 19045155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *getoptions(void); 1905c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid change_flag(enum sh_flag, int, bool); 19065155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint parse_args(const char **, int, bool *); 19075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint getn(const char *, int *); 19085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint gmatchx(const char *, const char *, bool); 19095155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint has_globbing(const char *, const char *); 19105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint xstrcmp(const void *, const void *); 19115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid ksh_getopt_reset(Getopt *, int); 19125155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint ksh_getopt(const char **, Getopt *, const char *); 1913c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid print_value_quoted(struct shf *, const char *); 191403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrachar *quote_value(const char *); 1915c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid print_columns(struct shf *, unsigned int, 1916c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser char *(*)(char *, size_t, unsigned int, const void *), 191703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra const void *, size_t, size_t, bool); 19185155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid strip_nuls(char *, int); 191903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t blocking_read(int, char *, size_t) 192003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_BOUNDED(__buffer__, 2, 3); 19215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint reset_nonblock(int); 192203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrachar *ksh_get_wd(void); 192303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrachar *do_realpath(const char *); 19245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid simplify_path(char *); 192503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid set_current_wd(const char *); 192603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint c_cd(const char **); 1927c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(MKSH_SMALL) && !defined(MKSH_SMALL_BUT_FAST) 1928c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserchar *strdup_i(const char *, Area *); 1929c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserchar *strndup_i(const char *, size_t, Area *); 19305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 19315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint unbksl(bool, int (*)(void), void (*)(int)); 19325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* shf.c */ 19335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct shf *shf_open(const char *, int, int, int); 19345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct shf *shf_fdopen(int, int, struct shf *); 19355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct shf *shf_reopen(int, int, struct shf *); 193603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrastruct shf *shf_sopen(char *, ssize_t, int, struct shf *); 19375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shf_close(struct shf *); 19385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shf_fdclose(struct shf *); 19395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *shf_sclose(struct shf *); 19405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shf_flush(struct shf *); 194103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t shf_read(char *, ssize_t, struct shf *); 194203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrachar *shf_getse(char *, ssize_t, struct shf *); 19435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shf_getchar(struct shf *s); 19445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shf_ungetc(int, struct shf *); 1945c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#if defined(MKSH_SMALL) && !defined(MKSH_SMALL_BUT_FAST) 194603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint shf_getc(struct shf *); 194703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint shf_putc(int, struct shf *); 194803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#else 1949c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define shf_getc shf_getc_i 1950c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaser#define shf_putc shf_putc_i 195103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#endif 19525155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint shf_putchar(int, struct shf *); 195303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t shf_puts(const char *, struct shf *); 195403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t shf_write(const char *, ssize_t, struct shf *); 195503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t shf_fprintf(struct shf *, const char *, ...) 195603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 2, 3); 195703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t shf_snprintf(char *, ssize_t, const char *, ...) 195803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 3, 4) 195903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_BOUNDED(__string__, 1, 2); 19605155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *shf_smprintf(const char *, ...) 196103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 1, 2); 196203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrassize_t shf_vfprintf(struct shf *, const char *, va_list) 196303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_FORMAT(__printf__, 2, 0); 19645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* syn.c */ 19655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid initkeywords(void); 196603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrastruct op *compile(Source *, bool); 196703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrabool parse_usec(const char *, struct timeval *); 1968c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserchar *yyrecursive(int); 1969c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid yyrecursive_pop(bool); 19705155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* tree.c */ 197103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid fptreef(struct shf *, int, const char *, ...); 197203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrachar *snptreef(char *, ssize_t, const char *, ...); 19735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct op *tcopy(struct op *, Area *); 19745155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *wdcopy(const char *, Area *); 19755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruconst char *wdscan(const char *, int); 197603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define WDS_TPUTS BIT(0) /* tputS (dumpwdvar) mode */ 197703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define WDS_KEEPQ BIT(1) /* keep quote characters */ 197803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#define WDS_MAGIC BIT(2) /* make MAGIC */ 197903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrachar *wdstrip(const char *, int); 19805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid tfree(struct op *, Area *); 198103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid dumpchar(struct shf *, int); 198203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid dumptree(struct shf *, struct op *); 198303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid dumpwdvar(struct shf *, const char *); 1984c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid dumpioact(struct shf *shf, struct op *t); 198503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid vistree(char *, size_t, struct op *) 198603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra MKSH_A_BOUNDED(__string__, 1, 2); 198703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid fpFUNCTf(struct shf *, int, bool, const char *, struct op *); 19885155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* var.c */ 19895155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid newblock(void); 19905155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid popblock(void); 19915155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid initvar(void); 1992c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserstruct block *varsearch(struct block *, struct tbl **, const char *, uint32_t); 19935155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *global(const char *); 19945155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *local(const char *, bool); 19955155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *str_val(struct tbl *); 19965155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint setstr(struct tbl *, const char *, int); 19975155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querustruct tbl *setint_v(struct tbl *, struct tbl *, bool); 19985155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid setint(struct tbl *, mksh_ari_t); 1999c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaservoid setint_n(struct tbl *, mksh_ari_t, int); 2000c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserstruct tbl *typeset(const char *, uint32_t, uint32_t, int, int); 20015155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid unset(struct tbl *, int); 20025155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruconst char *skip_varname(const char *, int); 200303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraconst char *skip_wdvarname(const char *, bool); 200403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condraint is_wdvarname(const char *, bool); 20055155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint is_wdvarassign(const char *); 200603ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrastruct tbl *arraysearch(struct tbl *, uint32_t); 20075155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar **makenv(void); 20085155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruvoid change_winsz(void); 200903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrasize_t array_ref_len(const char *); 20105155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruchar *arrayname(const char *); 20115155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querumksh_uari_t set_array(const char *, bool, const char **); 201203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condrauint32_t hash(const void *); 2013c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glasermksh_ari_t rndget(void); 201403ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condravoid rndset(long); 20155155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20165155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruenum Test_op { 201703ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra /* non-operator */ 201803ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra TO_NONOP = 0, 20195155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru /* unary operators */ 20205155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_STNZE, TO_STZER, TO_OPTION, 20215155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_FILAXST, 20225155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_FILEXST, 20235155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_FILREG, TO_FILBDEV, TO_FILCDEV, TO_FILSYM, TO_FILFIFO, TO_FILSOCK, 20245155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_FILCDF, TO_FILID, TO_FILGID, TO_FILSETG, TO_FILSTCK, TO_FILUID, 20255155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_FILRD, TO_FILGZ, TO_FILTT, TO_FILSETU, TO_FILWR, TO_FILEX, 20265155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru /* binary operators */ 20275155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_STEQL, TO_STNEQ, TO_STLT, TO_STGT, TO_INTEQ, TO_INTNE, TO_INTGT, 20285155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_INTGE, TO_INTLT, TO_INTLE, TO_FILEQ, TO_FILNT, TO_FILOT, 20295155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru /* not an operator */ 20305155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TO_NONNULL /* !TO_NONOP */ 20315155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 20325155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef enum Test_op Test_op; 20335155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20345155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* Used by Test_env.isa() (order important - used to index *_tokens[] arrays) */ 20355155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruenum Test_meta { 20365155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_OR, /* -o or || */ 20375155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_AND, /* -a or && */ 20385155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_NOT, /* ! */ 20395155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_OPAREN, /* ( */ 20405155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_CPAREN, /* ) */ 20415155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_UNOP, /* unary operator */ 20425155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_BINOP, /* binary operator */ 20435155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru TM_END /* end of input */ 20445155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru}; 20455155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef enum Test_meta Test_meta; 20465155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20475155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TEF_ERROR BIT(0) /* set if we've hit an error */ 20485155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#define TEF_DBRACKET BIT(1) /* set if [[ .. ]] test */ 20495155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20505155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Querutypedef struct test_env { 20515155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru union { 205203ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra const char **wp; /* used by ptest_* */ 205303ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra XPtrV *av; /* used by dbtestp_* */ 20545155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru } pos; 205503ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra const char **wp_end; /* used by ptest_* */ 20565155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru Test_op (*isa)(struct test_env *, Test_meta); 20575155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru const char *(*getopnd) (struct test_env *, Test_op, bool); 20585155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru int (*eval)(struct test_env *, Test_op, const char *, const char *, bool); 20595155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru void (*error)(struct test_env *, int, const char *); 206003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra int flags; /* TEF_* */ 20615155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru} Test_env; 20625155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2063c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserextern const char * const dbtest_tokens[]; 20645155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20655155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste QueruTest_op test_isop(Test_meta, const char *); 20665155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint test_eval(Test_env *, Test_op, const char *, const char *, bool); 20675155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queruint test_parse(Test_env *); 20685155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 206903ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN int tty_fd E_INIT(-1); /* dup'd tty file descriptor */ 207003ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy CondraEXTERN bool tty_devtty; /* true if tty_fd is from /dev/tty */ 2071c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN mksh_ttyst tty_state; /* saved tty state */ 2072c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten GlaserEXTERN bool tty_hasstate; /* true if tty_state is valid */ 20735155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 2074c2dc5def5e2273bb1d78b4ba032a3903dd0f980cThorsten Glaserextern int tty_init_fd(void); /* initialise tty_fd, tty_devtty */ 20755155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20765155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru/* be sure not to interfere with anyone else's idea about EXTERN */ 20775155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#ifdef EXTERN_DEFINED 20785155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru# undef EXTERN_DEFINED 20795155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru# undef EXTERN 20805155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif 208103ebf06f4e1112a0e9533b93062d169232c4cbfeGeremy Condra#undef E_INIT 20825155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru 20835155f1c7438ef540d7b25eb70aa1639579795b07Jean-Baptiste Queru#endif /* !MKSH_INCLUDES_ONLY */ 2084