1
1
mc/slang/include/_slang.h
2005-11-12 19:47:49 +00:00

1407 строки
45 KiB
C

#ifndef PRIVATE_SLANG_H_
#define PRIVATE_SLANG_H_
/* header file for S-Lang internal structures that users do not (should not)
need. Use slang.h for that purpose. */
/*
Copyright (C) 2004, 2005 John E. Davis
This file is part of the S-Lang Library.
The S-Lang Library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The S-Lang Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA.
*/
/* #include "config.h" */
#include "jdmacros.h"
#include "sllimits.h"
#ifdef VMS
# define SLANG_SYSTEM_NAME "_VMS"
#else
# if defined (IBMPC_SYSTEM)
# define SLANG_SYSTEM_NAME "_IBMPC"
# else
# define SLANG_SYSTEM_NAME "_UNIX"
# endif
#endif /* VMS */
/* These quantities are main_types for byte-compiled code. They are used
* by the inner_interp routine. The _BC_ means byte-code.
*/
/* Nametype byte-codes --- these must correspond to those in slang.h */
typedef enum
{
SLANG_BC_LAST_BLOCK = 0,
SLANG_BC_LVARIABLE = SLANG_LVARIABLE, /* 0x01 */
SLANG_BC_GVARIABLE = SLANG_GVARIABLE, /* 0x02 */
SLANG_BC_IVARIABLE = SLANG_IVARIABLE, /* 0x03 */
SLANG_BC_RVARIABLE = SLANG_RVARIABLE, /* 0x04 */
SLANG_BC_INTRINSIC = SLANG_INTRINSIC, /* 0x05 */
SLANG_BC_FUNCTION = SLANG_FUNCTION, /* 0x06 */
SLANG_BC_MATH_UNARY = SLANG_MATH_UNARY, /* 0x07 */
SLANG_BC_APP_UNARY = SLANG_APP_UNARY, /* 0x08 */
SLANG_BC_ARITH_UNARY = SLANG_ARITH_UNARY, /* 0x09 */
SLANG_BC_ARITH_BINARY = SLANG_ARITH_BINARY, /* 0x0A */
SLANG_BC_ICONST = SLANG_ICONSTANT, /* 0x0B */
SLANG_BC_DCONST = SLANG_DCONSTANT, /* 0x0C */
SLANG_BC_FCONST = SLANG_FCONSTANT, /* 0x0D */
SLANG_BC_LLCONST = SLANG_LLCONSTANT, /* 0x0E */
SLANG_BC_PVARIABLE = SLANG_PVARIABLE, /* 0x0F */
SLANG_BC_PFUNCTION = SLANG_PFUNCTION, /* 0x10 */
SLANG_BC_HCONST = SLANG_HCONSTANT, /* 0x11 */
SLANG_BC_LCONST = SLANG_LCONSTANT, /* 0x12 */
SLANG_BC_UNUSED_0x12 = 0x12,
SLANG_BC_UNUSED_0x13 = 0x13,
SLANG_BC_UNUSED_0x14 = 0x14,
SLANG_BC_UNUSED_0x15 = 0x15,
SLANG_BC_UNUSED_0x16 = 0x16,
SLANG_BC_UNUSED_0x17 = 0x17,
SLANG_BC_UNUSED_0x18 = 0x18,
SLANG_BC_UNUSED_0x19 = 0x19,
SLANG_BC_UNUSED_0x1A = 0x1A,
SLANG_BC_UNUSED_0x1B = 0x1B,
SLANG_BC_UNUSED_0x1C = 0x1C,
SLANG_BC_UNUSED_0x1D = 0x1D,
SLANG_BC_UNUSED_0x1E = 0x1E,
SLANG_BC_UNUSED_0x1F = 0x1F,
/* bytes codes for setting/assigning variables/arrays/structures/refs */
SLANG_BC_SET_LOCAL_LVALUE = 0x20,
SLANG_BC_SET_GLOBAL_LVALUE = 0x21,
SLANG_BC_SET_INTRIN_LVALUE = 0x22,
SLANG_BC_SET_STRUCT_LVALUE = 0x23,
SLANG_BC_SET_ARRAY_LVALUE = 0x24,
SLANG_BC_SET_DEREF_LVALUE = 0x25,
SLANG_BC_FIELD = 0x26,
SLANG_BC_METHOD = 0x27,
SLANG_BC_LVARIABLE_AGET = 0x28,
SLANG_BC_LVARIABLE_APUT = 0x29,
SLANG_BC_LOBJPTR = 0x2A,
SLANG_BC_GOBJPTR = 0x2B,
SLANG_BC_UNUSED_0x2C = 0x2C,
SLANG_BC_UNUSED_0x2D = 0x2D,
SLANG_BC_UNUSED_0x2E = 0x2E,
SLANG_BC_UNUSED_0x2F = 0x2F,
SLANG_BC_UNUSED_0x30 = 0x30,
SLANG_BC_UNUSED_0x31 = 0x31,
SLANG_BC_UNUSED_0x32 = 0x32,
SLANG_BC_UNUSED_0x33 = 0x33,
SLANG_BC_UNUSED_0x34 = 0x34,
SLANG_BC_UNUSED_0x35 = 0x35,
SLANG_BC_UNUSED_0x36 = 0x36,
SLANG_BC_UNUSED_0x37 = 0x37,
SLANG_BC_UNUSED_0x38 = 0x38,
SLANG_BC_UNUSED_0x39 = 0x39,
SLANG_BC_UNUSED_0x3A = 0x3A,
SLANG_BC_UNUSED_0x3B = 0x3B,
SLANG_BC_UNUSED_0x3C = 0x3C,
SLANG_BC_UNUSED_0x3D = 0x3D,
SLANG_BC_UNUSED_0x3E = 0x3E,
SLANG_BC_UNUSED_0x3F = 0x3F,
/* byte codes for literals */
SLANG_BC_LITERAL = 0x40, /* constant objects */
SLANG_BC_LITERAL_INT = 0x41,
SLANG_BC_LITERAL_DBL = 0x42,
SLANG_BC_LITERAL_STR = 0x43,
SLANG_BC_DOLLAR_STR = 0x44,
SLANG_BC_LITERAL_SHORT = 0x45,
SLANG_BC_LITERAL_LONG = 0x46,
SLANG_BC_UNUSED_0x45 = 0x45,
SLANG_BC_UNUSED_0x46 = 0x46,
SLANG_BC_UNUSED_0x47 = 0x47,
SLANG_BC_UNUSED_0x48 = 0x48,
SLANG_BC_UNUSED_0x49 = 0x49,
SLANG_BC_UNUSED_0x4A = 0x4A,
SLANG_BC_UNUSED_0x4B = 0x4B,
SLANG_BC_UNUSED_0x4C = 0x4C,
SLANG_BC_UNUSED_0x4D = 0x4D,
SLANG_BC_UNUSED_0x4E = 0x4E,
SLANG_BC_UNUSED_0x4F = 0x4F,
/* Unary/Binary operation codes */
SLANG_BC_UNARY = 0x50,
SLANG_BC_BINARY = 0x51,
SLANG_BC_INTEGER_PLUS = 0x52,
SLANG_BC_INTEGER_MINUS = 0x53,
SLANG_BC_UNUSED_0x54 = 0x54,
SLANG_BC_UNUSED_0x55 = 0x55,
SLANG_BC_UNUSED_0x56 = 0x56,
SLANG_BC_UNUSED_0x57 = 0x57,
SLANG_BC_UNUSED_0x58 = 0x58,
SLANG_BC_UNUSED_0x59 = 0x59,
SLANG_BC_UNUSED_0x5A = 0x5A,
SLANG_BC_UNUSED_0x5B = 0x5B,
SLANG_BC_UNUSED_0x5C = 0x5C,
SLANG_BC_UNUSED_0x5D = 0x5D,
SLANG_BC_UNUSED_0x5E = 0x5E,
SLANG_BC_UNUSED_0x5F = 0x5F,
/* byte codes associated with keywords and blocks */
SLANG_BC_TMP = 0x60,
SLANG_BC_EXCH = 0x61,
SLANG_BC_LABEL = 0x62,
SLANG_BC_BLOCK = 0x63,
SLANG_BC_RETURN = 0x64,
SLANG_BC_BREAK = 0x65,
SLANG_BC_CONTINUE = 0x66,
SLANG_BC_IF_BLOCK = 0x67, /* optimized code */
SLANG_BC_UNUSED_0x68 = 0x68,
SLANG_BC_UNUSED_0x69 = 0x69,
SLANG_BC_X_ERROR = 0x6A,
SLANG_BC_X_USER0 = 0x6B,
SLANG_BC_X_USER1 = 0x6C,
SLANG_BC_X_USER2 = 0x6D,
SLANG_BC_X_USER3 = 0x6E,
SLANG_BC_X_USER4 = 0x6F,
/* byte codes for dealing with the frame pointer and arg list */
SLANG_BC_CALL_DIRECT = 0x70,
SLANG_BC_CALL_DIRECT_FRAME = 0x71,
/* SLANG_BC_ARG_LVARIABLE = 0x72, */
SLANG_BC_UNUSED_0x72 = 0x72,
SLANG_BC_EARG_LVARIABLE = 0x73,
SLANG_BC_LINE_NUM = 0x74,
SLANG_BC_BOS = 0x75,
SLANG_BC_EOS = 0x76,
SLANG_BC_UNUSED_0x77 = 0x77,
SLANG_BC_UNUSED_0x78 = 0x78,
SLANG_BC_UNUSED_0x79 = 0x79,
SLANG_BC_UNUSED_0x7A = 0x7A,
SLANG_BC_UNUSED_0x7B = 0x7B,
SLANG_BC_UNUSED_0x7C = 0x7C,
SLANG_BC_UNUSED_0x7D = 0x7D,
SLANG_BC_UNUSED_0x7E = 0x7E,
SLANG_BC_UNUSED_0x7F = 0x7F,
/* These are used only when compiled with USE_COMBINED_BYTECODES */
SLANG_BC_CALL_DIRECT_INTRINSIC= 0x80,
SLANG_BC_INTRINSIC_CALL_DIRECT= 0x81,
SLANG_BC_CALL_DIRECT_LSTR = 0x82,
SLANG_BC_CALL_DIRECT_SLFUN = 0x83,
SLANG_BC_CALL_DIRECT_RETINTR = 0x84,
SLANG_BC_RET_INTRINSIC = 0x85,
SLANG_BC_CALL_DIRECT_EARG_LVAR= 0x86,
SLANG_BC_CALL_DIRECT_LINT = 0x87,
SLANG_BC_CALL_DIRECT_LVAR = 0x88,
SLANG_BC_LLVARIABLE_BINARY = 0x89,
SLANG_BC_LGVARIABLE_BINARY = 0x8A,
SLANG_BC_GLVARIABLE_BINARY = 0x8B,
SLANG_BC_GGVARIABLE_BINARY = 0x8C,
SLANG_BC_LIVARIABLE_BINARY = 0x8D,
SLANG_BC_LDVARIABLE_BINARY = 0x8E,
SLANG_BC_ILVARIABLE_BINARY = 0x8F,
SLANG_BC_DLVARIABLE_BINARY = 0x90,
SLANG_BC_LVARIABLE_BINARY = 0x91,
SLANG_BC_GVARIABLE_BINARY = 0x92,
SLANG_BC_LITERAL_INT_BINARY = 0x93,
SLANG_BC_LITERAL_DBL_BINARY = 0x94,
SLANG_BC_LASSIGN_LLBINARY = 0x95,
SLANG_BC_LASSIGN_LIBINARY = 0x96,
SLANG_BC_LASSIGN_ILBINARY = 0x97,
SLANG_BC_LASSIGN_LDBINARY = 0x98,
SLANG_BC_LASSIGN_DLBINARY = 0x99,
SLANG_BC_RET_LVARIABLE = 0x9A,
SLANG_BC_RET_LITERAL_INT = 0x9B,
SLANG_BC_MANY_LVARIABLE = 0x9C,
SLANG_BC_MANY_LVARIABLE_DIR = 0x9D,
SLANG_BC_LVARIABLE_AGET1 = 0x9E,
SLANG_BC_LITERAL_AGET1 = 0x9F,
SLANG_BC_LVARIABLE_APUT1 = 0xA0,
SLANG_BC_LITERAL_APUT1 = 0xA1,
SLANG_BC_UNUSED_0xA2 = 0xA2,
SLANG_BC_UNUSED_0xA3 = 0xA3,
SLANG_BC_UNUSED_0xA4 = 0xA4,
SLANG_BC_UNUSED_0xA5 = 0xA5,
SLANG_BC_UNUSED_0xA6 = 0xA6,
SLANG_BC_UNUSED_0xA7 = 0xA7,
SLANG_BC_UNUSED_0xA8 = 0xA8,
SLANG_BC_UNUSED_0xA9 = 0xA9,
SLANG_BC_UNUSED_0xAA = 0xAA,
SLANG_BC_UNUSED_0xAB = 0xAB,
SLANG_BC_UNUSED_0xAC = 0xAC,
SLANG_BC_UNUSED_0xAD = 0xAD,
SLANG_BC_UNUSED_0xAE = 0xAE,
SLANG_BC_UNUSED_0xAF = 0xAF,
/* The following do not actually occur in inner_interp. They used
* to signify the bytecode has been combined with another.
*/
SLANG_BC_LVARIABLE_COMBINED = 0xB0,
SLANG_BC_GVARIABLE_COMBINED = 0xB1,
SLANG_BC_LITERAL_COMBINED = 0xB2,
SLANG_BC_CALL_DIRECT_COMB = 0xB3,
SLANG_BC_COMBINED = 0xB4,
SLANG_BC_UNUSED_0xB5 = 0xB5,
SLANG_BC_UNUSED_0xB6 = 0xB6,
SLANG_BC_UNUSED_0xB7 = 0xB7,
SLANG_BC_UNUSED_0xB8 = 0xB8,
SLANG_BC_UNUSED_0xB9 = 0xB9,
SLANG_BC_UNUSED_0xBA = 0xBA,
SLANG_BC_UNUSED_0xBB = 0xBB,
SLANG_BC_UNUSED_0xBC = 0xBC,
SLANG_BC_UNUSED_0xBD = 0xBD,
SLANG_BC_UNUSED_0xBE = 0xBE,
SLANG_BC_UNUSED_0xBF = 0xBF,
SLANG_BC_UNUSED_0xC0 = 0xC0,
SLANG_BC_UNUSED_0xC1 = 0xC1,
SLANG_BC_UNUSED_0xC2 = 0xC2,
SLANG_BC_UNUSED_0xC3 = 0xC3,
SLANG_BC_UNUSED_0xC4 = 0xC4,
SLANG_BC_UNUSED_0xC5 = 0xC5,
SLANG_BC_UNUSED_0xC6 = 0xC6,
SLANG_BC_UNUSED_0xC7 = 0xC7,
SLANG_BC_UNUSED_0xC8 = 0xC8,
SLANG_BC_UNUSED_0xC9 = 0xC9,
SLANG_BC_UNUSED_0xCA = 0xCA,
SLANG_BC_UNUSED_0xCB = 0xCB,
SLANG_BC_UNUSED_0xCC = 0xCC,
SLANG_BC_UNUSED_0xCD = 0xCD,
SLANG_BC_UNUSED_0xCE = 0xCE,
SLANG_BC_UNUSED_0xCF = 0xCF,
SLANG_BC_UNUSED_0xD0 = 0xD0,
SLANG_BC_UNUSED_0xD1 = 0xD1,
SLANG_BC_UNUSED_0xD2 = 0xD2,
SLANG_BC_UNUSED_0xD3 = 0xD3,
SLANG_BC_UNUSED_0xD4 = 0xD4,
SLANG_BC_UNUSED_0xD5 = 0xD5,
SLANG_BC_UNUSED_0xD6 = 0xD6,
SLANG_BC_UNUSED_0xD7 = 0xD7,
SLANG_BC_UNUSED_0xD8 = 0xD8,
SLANG_BC_UNUSED_0xD9 = 0xD9,
SLANG_BC_UNUSED_0xDA = 0xDA,
SLANG_BC_UNUSED_0xDB = 0xDB,
SLANG_BC_UNUSED_0xDC = 0xDC,
SLANG_BC_UNUSED_0xDD = 0xDD,
SLANG_BC_UNUSED_0xDE = 0xDE,
SLANG_BC_UNUSED_0xDF = 0xDF,
SLANG_BC_UNUSED_0xE0 = 0xE0,
SLANG_BC_UNUSED_0xE1 = 0xE1,
SLANG_BC_UNUSED_0xE2 = 0xE2,
SLANG_BC_UNUSED_0xE3 = 0xE3,
SLANG_BC_UNUSED_0xE4 = 0xE4,
SLANG_BC_UNUSED_0xE5 = 0xE5,
SLANG_BC_UNUSED_0xE6 = 0xE6,
SLANG_BC_UNUSED_0xE7 = 0xE7,
SLANG_BC_UNUSED_0xE8 = 0xE8,
SLANG_BC_UNUSED_0xE9 = 0xE9,
SLANG_BC_UNUSED_0xEA = 0xEA,
SLANG_BC_UNUSED_0xEB = 0xEB,
SLANG_BC_UNUSED_0xEC = 0xEC,
SLANG_BC_UNUSED_0xED = 0xED,
SLANG_BC_UNUSED_0xEE = 0xEE,
SLANG_BC_UNUSED_0xEF = 0xEF,
SLANG_BC_UNUSED_0xF0 = 0xF0,
SLANG_BC_UNUSED_0xF1 = 0xF1,
SLANG_BC_UNUSED_0xF2 = 0xF2,
SLANG_BC_UNUSED_0xF3 = 0xF3,
SLANG_BC_UNUSED_0xF4 = 0xF4,
SLANG_BC_UNUSED_0xF5 = 0xF5,
SLANG_BC_UNUSED_0xF6 = 0xF6,
SLANG_BC_UNUSED_0xF7 = 0xF7,
SLANG_BC_UNUSED_0xF8 = 0xF8,
SLANG_BC_UNUSED_0xF9 = 0xF9,
SLANG_BC_UNUSED_0xFA = 0xFA,
SLANG_BC_UNUSED_0xFB = 0xFB,
SLANG_BC_UNUSED_0xFC = 0xFC,
SLANG_BC_UNUSED_0xFD = 0xFD,
SLANG_BC_UNUSED_0xFE = 0xFE,
SLANG_BC_UNUSED_0xFF = 0xFF
}
_pSLang_BC_Type;
/* Byte-Code Sub Types (_BCST_) */
/* These are sub_types of SLANG_BC_BLOCK */
#define SLANG_BCST_ERROR_BLOCK 0x01
#define SLANG_BCST_EXIT_BLOCK 0x02
#define SLANG_BCST_USER_BLOCK0 0x03
#define SLANG_BCST_USER_BLOCK1 0x04
#define SLANG_BCST_USER_BLOCK2 0x05
#define SLANG_BCST_USER_BLOCK3 0x06
#define SLANG_BCST_USER_BLOCK4 0x07
/* The user blocks MUST be in the above order */
#define SLANG_BCST_LOOP 0x10
#define SLANG_BCST_WHILE 0x11
#define SLANG_BCST_FOR 0x12
#define SLANG_BCST_FOREVER 0x13
#define SLANG_BCST_CFOR 0x14
#define SLANG_BCST_DOWHILE 0x15
#define SLANG_BCST_FOREACH 0x16
#define SLANG_BCST_TRY 0x17
#define SLANG_BCST_IF 0x20
#define SLANG_BCST_IFNOT 0x21
#define SLANG_BCST_ELSE 0x22
#define SLANG_BCST_ANDELSE 0x23
#define SLANG_BCST_ORELSE 0x24
#define SLANG_BCST_SWITCH 0x25
#define SLANG_BCST_NOTELSE 0x26
/* assignment (SLANG_BC_SET_*_LVALUE) subtypes. The order MUST correspond
* to the assignment token order with the ASSIGN_TOKEN as the first!
*/
#define SLANG_BCST_ASSIGN 0x01
#define SLANG_BCST_PLUSEQS 0x02
#define SLANG_BCST_MINUSEQS 0x03
#define SLANG_BCST_TIMESEQS 0x04
#define SLANG_BCST_DIVEQS 0x05
#define SLANG_BCST_BOREQS 0x06
#define SLANG_BCST_BANDEQS 0x07
#define SLANG_BCST_PLUSPLUS 0x08
#define SLANG_BCST_POST_PLUSPLUS 0x09
#define SLANG_BCST_MINUSMINUS 0x0A
#define SLANG_BCST_POST_MINUSMINUS 0x0B
/* These use SLANG_PLUS, SLANG_MINUS, SLANG_PLUSPLUS, etc... */
#define LONG_IS_INT (SIZEOF_INT == SIZEOF_LONG)
#define LONG_IS_NOT_INT (SIZEOF_INT != SIZEOF_LONG)
#define SHORT_IS_INT (SIZEOF_INT == SIZEOF_SHORT)
#define SHORT_IS_NOT_INT (SIZEOF_INT != SIZEOF_SHORT)
#define LLONG_IS_LONG (SIZEOF_LONG == SIZEOF_LONG_LONG)
#define LLONG_IS_NOT_LONG (SIZEOF_LONG != SIZEOF_LONG_LONG)
/* If long or short are ints, then map the slang types to ints. This is
* done because slang has some optimizations for ints.
*/
#if LONG_IS_INT
# define _pSLANG_LONG_TYPE SLANG_INT_TYPE
# define _pSLANG_ULONG_TYPE SLANG_UINT_TYPE
#else
# define _pSLANG_LONG_TYPE SLANG_LONG_TYPE
# define _pSLANG_ULONG_TYPE SLANG_ULONG_TYPE
#endif
#if SHORT_IS_INT
# define _pSLANG_SHORT_TYPE SLANG_INT_TYPE
# define _pSLANG_USHORT_TYPE SLANG_UINT_TYPE
#else
# define _pSLANG_SHORT_TYPE SLANG_SHORT_TYPE
# define _pSLANG_USHORT_TYPE SLANG_USHORT_TYPE
#endif
#if LLONG_IS_LONG
# define _pSLANG_LLONG_TYPE _pSLANG_LONG_TYPE
# define _pSLANG_ULLONG_TYPE _pSLANG_ULONG_TYPE
#else
# define _pSLANG_LLONG_TYPE SLANG_LLONG_TYPE
# define _pSLANG_ULLONG_TYPE SLANG_ULLONG_TYPE
#endif
/* Map off_t to a slang type */
#if defined(HAVE_LONG_LONG) && (SIZEOF_OFF_T == SIZEOF_LONG_LONG) && (SIZEOF_LONG_LONG > SIZEOF_LONG)
# define SLANG_C_OFF_T_TYPE _pSLANG_LLONG_TYPE
typedef long long _pSLc_off_t_Type;
# define SLANG_PUSH_OFF_T SLang_push_long_long
#else
# if (SIZEOF_OFF_T == SIZEOF_INT)
# define SLANG_C_OFF_T_TYPE SLANG_INT_TYPE
# define SLANG_PUSH_OFF_T SLang_push_int
typedef int _pSLc_off_t_Type;
# else
# define SLANG_C_OFF_T_TYPE _pSLANG_LONG_TYPE
# define SLANG_PUSH_OFF_T SLang_push_long
typedef long _pSLc_off_t_Type;
# endif
#endif
#if SIZEOF_INT == 2
# define _pSLANG_INT16_TYPE SLANG_INT_TYPE
# define _pSLANG_UINT16_TYPE SLANG_UINT_TYPE
#else
# if SIZEOF_SHORT == 2
# define _pSLANG_INT16_TYPE SLANG_SHORT_TYPE
# define _pSLANG_UINT16_TYPE SLANG_USHORT_TYPE
# else
# if SIZEOF_LONG == 2
# define _pSLANG_INT16_TYPE SLANG_LONG_TYPE
# define _pSLANG_UINT16_TYPE SLANG_ULONG_TYPE
# else
# define _pSLANG_INT16_TYPE 0
# define _pSLANG_UINT16_TYPE 0
# endif
# endif
#endif
#if SIZEOF_INT == 4
# define _pSLANG_INT32_TYPE SLANG_INT_TYPE
# define _pSLANG_UINT32_TYPE SLANG_UINT_TYPE
#else
# if SIZEOF_SHORT == 4
# define _pSLANG_INT32_TYPE SLANG_SHORT_TYPE
# define _pSLANG_UINT32_TYPE SLANG_USHORT_TYPE
# else
# if SIZEOF_LONG == 4
# define _pSLANG_INT32_TYPE SLANG_LONG_TYPE
# define _pSLANG_UINT32_TYPE SLANG_ULONG_TYPE
# else
# define _pSLANG_INT32_TYPE 0
# define _pSLANG_UINT32_TYPE 0
# endif
# endif
#endif
#if SIZEOF_INT == 8
# define _pSLANG_INT64_TYPE SLANG_INT_TYPE
# define _pSLANG_UINT64_TYPE SLANG_UINT_TYPE
#else
# if SIZEOF_SHORT == 8
# define _pSLANG_INT64_TYPE SLANG_SHORT_TYPE
# define _pSLANG_UINT64_TYPE SLANG_USHORT_TYPE
# else
# if SIZEOF_LONG == 8
# define _pSLANG_INT64_TYPE SLANG_LONG_TYPE
# define _pSLANG_UINT64_TYPE SLANG_ULONG_TYPE
# else
# if SIZEOF_LONG_LONG == 8
# define _pSLANG_INT64_TYPE SLANG_LLONG_TYPE
# define _pSLANG_UINT64_TYPE SLANG_ULLONG_TYPE
# else
# define _pSLANG_INT64_TYPE 0
# define _pSLANG_UINT64_TYPE 0
# endif
# endif
# endif
#endif
typedef union
{
#if SLANG_HAS_FLOAT
double double_val;
float float_val;
#endif
#ifdef HAVE_LONG_LONG
long long llong_val;
unsigned long long ullong_val;
#endif
long long_val;
unsigned long ulong_val;
VOID_STAR ptr_val;
char *s_val;
int int_val;
unsigned int uint_val;
SLang_MMT_Type *ref;
SLang_Name_Type *n_val;
struct _pSLang_Struct_Type *struct_val;
struct _pSLang_Array_Type *array_val;
short short_val;
unsigned short ushort_val;
char char_val;
unsigned char uchar_val;
SLindex_Type index_val;
}
_pSL_Object_Union_Type;
typedef struct _pSLang_Object_Type
{
SLtype data_type; /* SLANG_INT_TYPE, ... */
_pSL_Object_Union_Type v;
}
SLang_Object_Type;
struct _pSLang_MMT_Type
{
SLtype data_type; /* int, string, etc... */
VOID_STAR user_data; /* address of user structure */
unsigned int count; /* number of references */
};
extern int _pSLang_pop_object_of_type (SLtype, SLang_Object_Type *, int);
typedef struct
{
char *name; /* slstring */
SLang_Object_Type obj;
}
_pSLstruct_Field_Type;
typedef struct _pSLang_Struct_Type
{
_pSLstruct_Field_Type *fields;
unsigned int nfields; /* number used */
unsigned int num_refs;
/* user-defined methods */
SLang_Name_Type *destroy_method;
}
_pSLang_Struct_Type;
extern void _pSLstruct_delete_struct (_pSLang_Struct_Type *);
extern int _pSLang_push_struct (_pSLang_Struct_Type *);
extern int _pSLang_pop_struct (_pSLang_Struct_Type **);
extern int _pSLstruct_init (void);
/* extern int _pSLstruct_get_field (char *); */
extern int _pSLstruct_define_struct (void);
extern int _pSLstruct_define_typedef (void);
struct _pSLang_Ref_Type
{
int is_global;
union
{
SLang_Name_Type *nt;
SLang_Object_Type *local_obj;
}
v;
};
extern int _pSLang_dereference_ref (SLang_Ref_Type *);
extern int _pSLang_deref_assign (SLang_Ref_Type *);
extern int _pSLang_push_ref (int, VOID_STAR);
extern int _pSL_increment_frame_pointer (void);
extern int _pSL_decrement_frame_pointer (void);
extern int SLang_pop(SLang_Object_Type *);
extern void SLang_free_object (SLang_Object_Type *);
extern int _pSLanytype_typecast (SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR);
extern void _pSLstring_intrinsic (void);
#if 0
/* NULL not allowed here */
extern char *_pSLmalloced_to_slstring (char *, unsigned int);
/* But here it is ok */
extern int _pSLpush_malloced_string (char *, unsigned int);
#endif
/* These functions are used to create slstrings of a fixed length. Be
* very careful how they are used. In particular, if len bytes are allocated,
* then the string must be len characters long, no more and no less.
*/
extern char *_pSLallocate_slstring (unsigned int);
extern char *_pSLcreate_via_alloced_slstring (char *, unsigned int);
extern void _pSLunallocate_slstring (char *, unsigned int);
extern int _pSLpush_alloced_slstring (char *, unsigned int);
extern unsigned int _pSLstring_bytelen (SLstr_Type *);
extern void _pSLang_free_slstring (SLstr_Type *); /* slstring required and assumed */
extern unsigned long _pSLstring_get_hash (SLstr_Type *s); /* slstring required */
typedef struct
{
char **buf;
unsigned int max_num;
unsigned int num;
unsigned int delta_num;
int is_malloced; /* non-zero if object was malloced */
}
_pSLString_List_Type;
/* Note that _pSLstring_list_append makes no copy of the object-- it steals it.
* For a copy, use _pSLstring_list_append_copy */
extern int _pSLstring_list_append (_pSLString_List_Type *, char *);
extern int _pSLstring_list_append_copy (_pSLString_List_Type *, char *);
extern int _pSLstring_list_init (_pSLString_List_Type *, unsigned int, unsigned int);
extern _pSLString_List_Type *_pSLstring_list_new (unsigned int, unsigned int);
extern void _pSLstring_list_delete (_pSLString_List_Type *);
extern int _pSLstring_list_push (_pSLString_List_Type *, int);
extern SLang_Array_Type *_pSLstrings_to_array (char **strs, unsigned int n);
/* This function assumes that s is an slstring. */
extern char *_pSLstring_dup_slstring (char *);
extern int _pSLang_dup_and_push_slstring (char *);
extern int _pSLang_init_import (void);
extern int _pSLinit_exceptions (void);
/* This function checks to see if the referenced object is initialized */
extern int _pSLang_is_ref_initialized (SLang_Ref_Type *);
extern int _pSLcheck_identifier_syntax (char *);
extern int _pSLang_uninitialize_ref (SLang_Ref_Type *);
extern int _pSLpush_slang_obj (SLang_Object_Type *);
extern char *_pSLexpand_escaped_char(char *, SLwchar_Type *, int *);
extern void _pSLexpand_escaped_string (char *, char *, char *);
/* returns a pointer to an SLstring string-- use SLang_free_slstring */
extern char *_pSLstringize_object (SLang_Object_Type *);
extern int _pSLdump_objects (char *, SLang_Object_Type *, unsigned int, int);
extern SLang_Object_Type *_pSLang_get_run_stack_pointer (void);
extern SLang_Object_Type *_pSLang_get_run_stack_base (void);
extern int _pSLang_dump_stack (void);
extern int _pSLang_peek_at_stack2 (SLtype *);
struct _pSLang_NameSpace_Type
{
struct _pSLang_NameSpace_Type *next;
char *name; /* this is the load_type name */
char *namespace_name; /* this name is assigned by implements */
char *private_name;
unsigned int table_size;
SLang_Name_Type **table;
};
extern SLang_NameSpace_Type *_pSLns_new_namespace (char *, unsigned int);
extern SLang_NameSpace_Type *_pSLns_allocate_namespace (char *, unsigned int);
extern void _pSLns_deallocate_namespace (SLang_NameSpace_Type *);
extern SLang_NameSpace_Type *_pSLns_find_namespace (char *);
extern int _pSLns_set_namespace_name (SLang_NameSpace_Type *, char *);
extern SLang_Array_Type *_pSLnspace_apropos (SLang_NameSpace_Type *, char *, unsigned int);
extern void _pSLang_use_namespace_intrinsic (char *name);
extern char *_pSLang_cur_namespace_intrinsic (void);
extern SLang_Array_Type *_pSLang_apropos (char *, char *, unsigned int);
extern void _pSLang_implements_intrinsic (char *);
extern SLang_Array_Type *_pSLns_list_namespaces (void);
extern SLang_Name_Type *_pSLns_locate_hashed_name (SLang_NameSpace_Type *, char *, unsigned long);
extern int _pSLns_add_hashed_name (SLang_NameSpace_Type *, SLang_Name_Type *, unsigned long);
extern SLang_NameSpace_Type *_pSLns_find_object_namespace (SLang_Name_Type *nt);
extern SLang_Name_Type *_pSLns_locate_name (SLang_NameSpace_Type *, char *);
extern SLang_NameSpace_Type *_pSLns_get_private_namespace (char *name, char *nsname);
extern SLang_NameSpace_Type *_pSLns_create_namespace2 (char *name, char *nsname);
extern int _pSLang_Trace;
extern char *_pSLang_current_function_name (void);
extern int _pSLang_trace_fun(char *);
/* This is a bitmapped variable */
extern int _pSLang_Compile_Line_Num_Info;
#if SLANG_HAS_BOSEOS
extern int _pSLang_Compile_BOSEOS;
extern int _pSLang_init_boseos (void);
extern int _pSLcall_bos_handler (char *, int);
extern int _pSLcall_eos_handler (void);
extern int _pSLcall_debug_hook (char *file, int linenum);
/* extern int _pSLcall_debug_hook (char *file, int linenum, char *funct); */
#endif
extern char *_pSLstring_dup_hashed_string (char *, unsigned long);
extern unsigned long _pSLcompute_string_hash (char *);
extern char *_pSLstring_make_hashed_string (char *, unsigned int, unsigned long *);
extern void _pSLfree_hashed_string (char *, unsigned int, unsigned long);
unsigned long _pSLstring_hash (unsigned char *, unsigned char *);
extern int _pSLinit_slcomplex (void);
extern int _pSLang_init_slstrops (void);
extern int _pSLstrops_do_sprintf_n (int);
extern int _pSLang_sscanf (void);
extern double _pSLang_atof (char *);
extern int _pSLang_init_bstring (void);
extern int _pSLang_init_sltime (void);
extern void _pSLpack (void);
extern void _pSLunpack (char *, SLang_BString_Type *);
extern void _pSLpack_pad_format (char *);
extern unsigned int _pSLpack_compute_size (char *);
extern int _pSLusleep (unsigned long);
/* frees upon error. NULL __NOT__ ok. */
extern int _pSLang_push_slstring (char *);
extern SLtype _pSLarith_promote_type (SLtype);
extern int _pSLarith_get_precedence (SLtype);
extern int _pSLarith_typecast (SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR);
extern int SLang_push(SLang_Object_Type *);
extern int SLadd_global_variable (char *);
extern int _pSLdo_pop (void);
extern unsigned int _pSLsys_getkey (void);
extern int _pSLsys_input_pending (int);
#ifdef IBMPC_SYSTEM
extern unsigned int _pSLpc_convert_scancode (unsigned int, unsigned int, int);
#define _pSLTT_KEY_SHIFT 1
#define _pSLTT_KEY_CTRL 2
#define _pSLTT_KEY_ALT 4
#endif
typedef struct _pSLterminfo_Type SLterminfo_Type;
extern SLterminfo_Type *_pSLtt_tigetent (char *);
extern char *_pSLtt_tigetstr (SLterminfo_Type *, char *);
extern int _pSLtt_tigetnum (SLterminfo_Type *, char *);
extern int _pSLtt_tigetflag (SLterminfo_Type *, char *);
#if SLTT_HAS_NON_BCE_SUPPORT
extern int _pSLtt_get_bce_color_offset (void);
#endif
extern void (*_pSLtt_color_changed_hook)(void);
extern unsigned char SLang_Input_Buffer [SL_MAX_INPUT_BUFFER_LEN];
typedef struct SL_OOBinary_Type
{
SLtype data_type; /* partner type for binary op */
int (*binary_function)_PROTO((int,
SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR, unsigned int,
VOID_STAR));
int (*binary_result) _PROTO((int, SLtype, SLtype, SLtype *));
struct SL_OOBinary_Type *next;
}
SL_OOBinary_Type;
typedef struct _pSL_Typecast_Type
{
SLtype data_type; /* to_type */
int allow_implicit;
int (*typecast)_PROTO((SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR));
struct _pSL_Typecast_Type *next;
}
SL_Typecast_Type;
struct _pSLang_Class_Type
{
SLclass_Type cl_class_type; /* vector, scalar, mmt, pointer */
unsigned int cl_data_type; /* SLANG_INTEGER_TYPE, etc... */
char *cl_name; /* slstring type */
size_t cl_sizeof_type;
VOID_STAR cl_transfer_buf; /* cl_sizeof_type bytes*/
/* Methods */
/* Most of the method functions are prototyped:
* int method (SLtype type, VOID_STAR addr);
* Here, @type@ represents the type of object that the method is asked
* to deal with. The second parameter @addr@ will contain the ADDRESS of
* the object. For example, if type is SLANG_INT_TYPE, then @addr@ will
* actually be int *. Similary, if type is SLANG_STRING_TYPE,
* then @addr@ will contain the address of the string, i.e., char **.
*/
void (*cl_destroy)_PROTO((SLtype, VOID_STAR));
/* Prototype: void destroy(unsigned type, VOID_STAR val)
* Called to delete/free the object */
char *(*cl_string)_PROTO((SLtype, VOID_STAR));
/* Prototype: char *to_string (SLtype t, VOID_STAR p);
* Here p is a pointer to the object for which a string representation
* is to be returned. The returned pointer is to be a MALLOCED string.
*/
/* Prototype: void push(SLtype type, VOID_STAR v);
* Push a copy of the object of type @type@ at address @v@ onto the
* stack.
*/
int (*cl_push)_PROTO((SLtype, VOID_STAR));
/* Prototype: int pop(SLtype type, VOID_STAR v);
* Pops value from stack and assign it to object, whose address is @v@.
*/
int (*cl_pop)_PROTO((SLtype, VOID_STAR));
/* mul2, sign, etc... */
int (*cl_unary_op_result_type)_PROTO((int, SLtype, SLtype *));
int (*cl_unary_op)_PROTO((int, SLtype, VOID_STAR, unsigned int, VOID_STAR));
#if 0
int (*cl_arith_unary_op_result_type)_PROTO((int, SLtype, SLtype *));
int (*cl_arith_unary_op)_PROTO((int, SLtype, VOID_STAR, unsigned int, VOID_STAR));
#endif
int (*cl_app_unary_op_result_type)_PROTO((int, SLtype, SLtype *));
int (*cl_app_unary_op)_PROTO((int, SLtype, VOID_STAR, unsigned int, VOID_STAR));
/* If this function is non-NULL, it will be called for sin, cos, etc... */
int (*cl_math_op)_PROTO((int, SLtype, VOID_STAR, unsigned int, VOID_STAR));
int (*cl_math_op_result_type)_PROTO((int, SLtype, SLtype *));
SL_OOBinary_Type *cl_binary_ops;
SL_Typecast_Type *cl_typecast_funs;
void (*cl_byte_code_destroy)_PROTO((SLtype, VOID_STAR));
void (*cl_user_destroy_fun)_PROTO((SLtype, VOID_STAR));
int (*cl_init_array_object)_PROTO((SLtype, VOID_STAR));
int (*cl_datatype_deref)_PROTO((SLtype));
SLang_Struct_Type *cl_struct_def;
int (*cl_dereference) _PROTO((SLtype, VOID_STAR));
int (*cl_acopy) (SLtype, VOID_STAR, VOID_STAR);
int (*cl_apop) _PROTO((SLtype, VOID_STAR));
int (*cl_apush) _PROTO((SLtype, VOID_STAR));
int (*cl_push_literal) _PROTO((SLtype, VOID_STAR));
void (*cl_adestroy)_PROTO((SLtype, VOID_STAR));
int (*cl_push_intrinsic)_PROTO((SLtype, VOID_STAR));
int (*cl_void_typecast)_PROTO((SLtype, VOID_STAR, unsigned int, SLtype, VOID_STAR));
int (*cl_anytype_typecast)_PROTO((SLtype, VOID_STAR, unsigned int, SLtype, VOID_STAR));
/* Array access functions */
int (*cl_aput) (SLtype, unsigned int);
int (*cl_aget) (SLtype, unsigned int);
int (*cl_anew) (SLtype, unsigned int);
/* length method */
int (*cl_length) (SLtype, VOID_STAR, unsigned int *);
/* foreach */
SLang_Foreach_Context_Type *(*cl_foreach_open) (SLtype, unsigned int);
void (*cl_foreach_close) (SLtype, SLang_Foreach_Context_Type *);
int (*cl_foreach) (SLtype, SLang_Foreach_Context_Type *);
/* Structure access: get and put (assign to) fields */
int (*cl_sput) (SLtype, char *);
int (*cl_sget) (SLtype, char *);
/* File I/O */
int (*cl_fread) (SLtype, FILE *, VOID_STAR, unsigned int, unsigned int *);
int (*cl_fwrite) (SLtype, FILE *, VOID_STAR, unsigned int, unsigned int *);
int (*cl_fdread) (SLtype, int, VOID_STAR, unsigned int, unsigned int *);
int (*cl_fdwrite) (SLtype, int, VOID_STAR, unsigned int, unsigned int *);
int (*cl_to_bool) (SLtype, int *);
int (*cl_cmp)(SLtype, VOID_STAR, VOID_STAR, int *);
int (*cl_eqs)(SLtype, VOID_STAR, SLtype, VOID_STAR);
SL_OOBinary_Type *cl_void_binary_this;
SL_OOBinary_Type *cl_this_binary_void;
int is_container;
};
extern int _pSLregister_types (void);
extern SLang_Class_Type *_pSLclass_get_class (SLtype);
extern VOID_STAR _pSLclass_get_ptr_to_value (SLang_Class_Type *, SLang_Object_Type *);
extern void _pSLclass_type_mismatch_error (SLtype, SLtype);
extern int _pSLclass_init (void);
extern int _pSLclass_copy_class (SLtype, SLtype);
extern int (*_pSLclass_get_typecast (SLtype, SLtype, int))
(SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR);
extern int (*_pSLclass_get_binary_fun (int, SLang_Class_Type *, SLang_Class_Type *, SLang_Class_Type **, int))
(int,
SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR, unsigned int,
VOID_STAR);
extern int (*_pSLclass_get_unary_fun (int, SLang_Class_Type *, SLang_Class_Type **, int))
(int, SLtype, VOID_STAR, unsigned int, VOID_STAR);
#if 0
extern int _pSLclass_add_arith_unary_op (SLtype type,
int (*f)(int,
SLtype, VOID_STAR, unsigned int,
VOID_STAR),
int (*r)(int, SLtype, SLtype *));
#endif
extern int _pSLclass_get_unary_opcode (char *name);
extern int _pSLclass_get_binary_opcode (char *name);
extern int _pSLclass_is_same_obj (SLang_Object_Type *a, SLang_Object_Type *b);
extern int _pSLclass_obj_eqs (SLang_Object_Type *a, SLang_Object_Type *b);
extern int _pSLarith_register_types (void);
extern SLtype _pSLarith_Arith_Types [];
extern int _pSLang_ref_is_callable (SLang_Ref_Type *);
extern int _pSLang_is_arith_type (SLtype);
extern void _pSLang_set_arith_type (SLtype, unsigned char);
#if SLANG_OPTIMIZE_FOR_SPEED
extern SLclass_Type _pSLang_get_class_type (SLtype);
extern void _pSLang_set_class_info (SLtype, SLang_Class_Type *);
#endif
extern int _pSLarith_bin_op (SLang_Object_Type *, SLang_Object_Type *, int);
extern int _pSLarray_add_bin_op (SLtype);
typedef struct
{
char *name;
SLang_Name_Type *next;
char name_type;
int unary_op;
}
SLang_Arith_Unary_Type;
extern int _pSLadd_arith_unary_table (SLang_Arith_Unary_Type *tbl, char *);
typedef struct
{
char *name;
SLang_Name_Type *next;
char name_type;
int binary_op;
}
SLang_Arith_Binary_Type;
extern int _pSLadd_arith_binary_table (SLang_Arith_Binary_Type *tbl, char *);
extern int _pSLang_call_funptr (SLang_Name_Type *);
extern void _pSLset_double_format (char *);
extern SLang_Name_Type *_pSLlocate_global_name (char *);
extern SLang_Name_Type *_pSLlocate_name (char *);
extern char *_pSLdefines[];
#define SL_ERRNO_NOT_IMPLEMENTED 0x7FFF
extern int _pSLerrno_errno;
extern int _pSLerrno_init (void);
extern int _pSLstdio_fdopen (char *, int, char *);
extern void _pSLstruct_pop_args (int *);
extern void _pSLstruct_push_args (SLang_Array_Type *);
extern int _pSLang_init_sllist (void);
extern int _pSLlist_inline_list (void);
extern int _pSLarray_aput1 (unsigned int);
extern int _pSLarray_aput (void);
extern int _pSLarray_aget (void);
extern int _pSLarray_aget1 (unsigned int);
extern int _pSLarray_inline_implicit_array (void);
extern int _pSLarray_inline_array (void);
extern int _pSLarray_wildcard_array (void);
extern int
_pSLarray_typecast (SLtype, VOID_STAR, unsigned int,
SLtype, VOID_STAR, int);
extern int _pSLarray_aput_transfer_elem (SLang_Array_Type *, SLindex_Type *,
VOID_STAR, size_t, int);
extern int _pSLarray_aget_transfer_elem (SLang_Array_Type *, SLindex_Type *,
VOID_STAR, size_t, int);
extern void _pSLarray_free_array_elements (SLang_Class_Type *, VOID_STAR, SLuindex_Type);
extern SLang_Foreach_Context_Type *
_pSLarray_cl_foreach_open (SLtype, unsigned int);
extern void _pSLarray_cl_foreach_close (SLtype, SLang_Foreach_Context_Type *);
extern int _pSLarray_cl_foreach (SLtype, SLang_Foreach_Context_Type *);
extern int _pSLarray_matrix_multiply (void);
extern void (*_pSLang_Matrix_Multiply)(void);
extern int _pSLarray_next_index (SLindex_Type *, SLindex_Type *, unsigned int);
extern int _pSLarray_init_slarray (void);
extern SLang_Array_Type *
SLang_create_array1 (SLtype, int, VOID_STAR, SLindex_Type *, unsigned int, int);
extern int _pSLassoc_aput (SLtype, unsigned int);
extern int _pSLassoc_aget (SLtype, unsigned int);
extern int _pSLcompile_push_context (SLang_Load_Type *);
extern int _pSLcompile_pop_context (void);
extern int _pSLang_Auto_Declare_Globals;
typedef struct _pSLang_Token_Type
{
union
{
long long_val;
unsigned long ulong_val;
#if HAVE_LONG_LONG
long long llong_val;
unsigned long long ullong_val;
#endif
/* Note that it is not wise to put a double field in the union because
* when reading a preparsed file, I want to keep the user-specified
* form to preserve the precision. Using a union member would mean
* converting the double to a string when creating a preparsed file.
* We can avoid the issues associated with this by just storing
* floating point values as strings.
*/
char *s_val; /* Used for IDENT_TOKEN, DOUBLE_TOKEN, etc... */
SLang_BString_Type *b_val;
} v;
int free_sval_flag;
unsigned int num_refs;
unsigned long hash;
#if SLANG_HAS_DEBUG_CODE
int line_number;
#endif
struct _pSLang_Token_Type *next; /* used for token lists */
SLtype type;
}
_pSLang_Token_Type;
extern void _pSLcompile (_pSLang_Token_Type *);
extern void (*_pSLcompile_ptr)(_pSLang_Token_Type *);
/* slmisc.c */
extern char *_pSLskip_whitespace (char *s);
/* slospath.c */
extern char *_pSLpath_find_file (char *); /* slstring returned */
/* Read but do not set this variable. */
extern volatile int _pSLang_Error;
extern int _pSLutf8_mode;
extern int _pSLinterp_UTF8_Mode; /* non-zero for interpreter */
extern int _pSLtt_UTF8_Mode;
extern SLuchar_Type *_pSLinterp_decode_wchar (SLuchar_Type *u,
SLuchar_Type *umax,
SLwchar_Type *chp);
extern SLuchar_Type *_pSLinterp_encode_wchar (SLwchar_Type wch,
SLuchar_Type *buf,
unsigned int *encoded_lenp);
/* *** TOKENS *** */
/* Note that that tokens corresponding to ^J, ^M, and ^Z should not be used.
* This is because a file that contains any of these characters will
* have an OS dependent interpretation, e.g., ^Z is EOF on MSDOS.
*/
/* Special tokens */
#define ILLEGAL_TOKEN 0x00 /* no token has this value */
#define EOF_TOKEN 0x01
#define RPN_TOKEN 0x02
#define NL_TOKEN 0x03
#define NOP_TOKEN 0x05
#define FARG_TOKEN 0x06
#define TMP_TOKEN 0x07
#define RESERVED1_TOKEN 0x0A /* \n */
#define RESERVED2_TOKEN 0x0D /* \r */
/* Literal tokens */
#define CHAR_TOKEN 0x10
#define UCHAR_TOKEN 0x11
#define SHORT_TOKEN 0x12
#define USHORT_TOKEN 0x13
#define INT_TOKEN 0x14
#define UINT_TOKEN 0x15
#define LONG_TOKEN 0x16
#define ULONG_TOKEN 0x17
#define IS_INTEGER_TOKEN(x) ((x >= CHAR_TOKEN) && (x <= ULONG_TOKEN))
#define FLOAT_TOKEN 0x18
#define DOUBLE_TOKEN 0x19
#define RESERVED3_TOKEN 0x1A /* ^Z */
#define COMPLEX_TOKEN 0x1B
#define STRING_TOKEN 0x1C
#define BSTRING_TOKEN 0x1D
#define _BSTRING_TOKEN 0x1E /* byte-compiled BSTRING */
#define STRING_DOLLAR_TOKEN 0x1F
/* Tokens that can be LVALUES */
#define IDENT_TOKEN 0x20
#define ARRAY_TOKEN 0x21
#define DOT_TOKEN 0x22
#define IS_LVALUE_TOKEN (((t) <= DOT_TOKEN) && ((t) >= IDENT_TOKEN))
#define DOT_METHOD_CALL_TOKEN 0x23
#define ESC_STRING_TOKEN 0x24
#define ESC_BSTRING_TOKEN 0x25
/* Flags for struct fields */
#define STATIC_TOKEN 0x26
#define READONLY_TOKEN 0x27
#define PRIVATE_TOKEN 0x28
#define PUBLIC_TOKEN 0x29
/* Punctuation tokens */
#define OBRACKET_TOKEN 0x2a
#define CBRACKET_TOKEN 0x2b
#define OPAREN_TOKEN 0x2c
#define CPAREN_TOKEN 0x2d
#define OBRACE_TOKEN 0x2e
#define CBRACE_TOKEN 0x2f
#define COMMA_TOKEN 0x31
#define SEMICOLON_TOKEN 0x32
#define COLON_TOKEN 0x33
#define NAMESPACE_TOKEN 0x34
/* Operators */
#define POW_TOKEN 0x38
/* The order here must match the order in the Binop_Level table in slparse.c */
#define FIRST_BINARY_OP 0x39
#define ADD_TOKEN 0x39
#define SUB_TOKEN 0x3a
#define TIMES_TOKEN 0x3b
#define DIV_TOKEN 0x3c
#define LT_TOKEN 0x3d
#define LE_TOKEN 0x3e
#define GT_TOKEN 0x3f
#define GE_TOKEN 0x40
#define EQ_TOKEN 0x41
#define NE_TOKEN 0x42
#define AND_TOKEN 0x43
#define OR_TOKEN 0x44
#define MOD_TOKEN 0x45
#define BAND_TOKEN 0x46
#define SHL_TOKEN 0x47
#define SHR_TOKEN 0x48
#define BXOR_TOKEN 0x49
#define BOR_TOKEN 0x4a
#define POUND_TOKEN 0x4b /* matrix multiplication */
#define LAST_BINARY_OP 0x4b
#define IS_BINARY_OP(t) ((t >= FIRST_BINARY_OP) && (t <= LAST_BINARY_OP))
/* unary tokens -- but not all of them (see grammar) */
#define DEREF_TOKEN 0x4d
#define NOT_TOKEN 0x4e
#define BNOT_TOKEN 0x4f
#define IS_INTERNAL_FUNC(t) ((t >= 0x50) && (t <= 0x52))
#define POP_TOKEN 0x50
#define CHS_TOKEN 0x51
#define EXCH_TOKEN 0x52
#define LLONG_TOKEN 0x53
#define ULLONG_TOKEN 0x54
#define LDOUBLE_TOKEN 0x55
/* Assignment tokens. Note: these must appear with sequential values.
* The order here must match the specific lvalue assignments below.
* These tokens are used by rpn routines in slang.c. slparse.c maps them
* onto the specific lvalue tokens while parsing infix.
* Also the assignment SLANG_BCST_ assumes this order
*/
#define ASSIGN_TOKEN 0x57
#define PLUSEQS_TOKEN 0x58
#define MINUSEQS_TOKEN 0x59
#define TIMESEQS_TOKEN 0x5A
#define DIVEQS_TOKEN 0x5B
#define BOREQS_TOKEN 0x5C
#define BANDEQS_TOKEN 0x5D
#define PLUSPLUS_TOKEN 0x5E
#define POST_PLUSPLUS_TOKEN 0x5F
#define MINUSMINUS_TOKEN 0x60
#define POST_MINUSMINUS_TOKEN 0x61
/* Directives */
#define FIRST_DIRECTIVE_TOKEN 0x62
#define IFNOT_TOKEN 0x62
#define IF_TOKEN 0x63
#define ELSE_TOKEN 0x64
#define FOREVER_TOKEN 0x65
#define WHILE_TOKEN 0x66
#define FOR_TOKEN 0x67
#define _FOR_TOKEN 0x68
#define LOOP_TOKEN 0x69
#define SWITCH_TOKEN 0x6A
#define DOWHILE_TOKEN 0x6B
#define ANDELSE_TOKEN 0x6C
#define ORELSE_TOKEN 0x6D
#define ERRBLK_TOKEN 0x6E
#define EXITBLK_TOKEN 0x6F
/* These must be sequential */
#define USRBLK0_TOKEN 0x70
#define USRBLK1_TOKEN 0x71
#define USRBLK2_TOKEN 0x72
#define USRBLK3_TOKEN 0x73
#define USRBLK4_TOKEN 0x74
#define CONT_TOKEN 0x75
#define BREAK_TOKEN 0x76
#define RETURN_TOKEN 0x77
#define CASE_TOKEN 0x78
#define DEFINE_TOKEN 0x79
#define DO_TOKEN 0x7a
#define VARIABLE_TOKEN 0x7b
#define GVARIABLE_TOKEN 0x7c
#define _REF_TOKEN 0x7d
#define PUSH_TOKEN 0x7e
#define STRUCT_TOKEN 0x7f
#define TYPEDEF_TOKEN 0x80
#define NOTELSE_TOKEN 0x81
#define DEFINE_STATIC_TOKEN 0x82
#define FOREACH_TOKEN 0x83
#define USING_TOKEN 0x84
#define DEFINE_PRIVATE_TOKEN 0x85
#define DEFINE_PUBLIC_TOKEN 0x86
#define TRY_TOKEN 0x87
#define CATCH_TOKEN 0x88
#define THROW_TOKEN 0x89
#define FINALLY_TOKEN 0x8a
/* Note: the order here must match the order of the generic assignment tokens.
* Also, the first token of each group must be the ?_ASSIGN_TOKEN.
* slparse.c exploits this order, as well as slang.h.
*/
#define FIRST_ASSIGN_TOKEN 0x90
#define _STRUCT_ASSIGN_TOKEN 0x90
#define _STRUCT_PLUSEQS_TOKEN 0x91
#define _STRUCT_MINUSEQS_TOKEN 0x92
#define _STRUCT_TIMESEQS_TOKEN 0x93
#define _STRUCT_DIVEQS_TOKEN 0x94
#define _STRUCT_BOREQS_TOKEN 0x95
#define _STRUCT_BANDEQS_TOKEN 0x96
#define _STRUCT_PLUSPLUS_TOKEN 0x97
#define _STRUCT_POST_PLUSPLUS_TOKEN 0x98
#define _STRUCT_MINUSMINUS_TOKEN 0x99
#define _STRUCT_POST_MINUSMINUS_TOKEN 0x9A
#define _ARRAY_ASSIGN_TOKEN 0xA0
#define _ARRAY_PLUSEQS_TOKEN 0xA1
#define _ARRAY_MINUSEQS_TOKEN 0xA2
#define _ARRAY_TIMESEQS_TOKEN 0xA3
#define _ARRAY_DIVEQS_TOKEN 0xA4
#define _ARRAY_BOREQS_TOKEN 0xA5
#define _ARRAY_BANDEQS_TOKEN 0xA6
#define _ARRAY_PLUSPLUS_TOKEN 0xA7
#define _ARRAY_POST_PLUSPLUS_TOKEN 0xA8
#define _ARRAY_MINUSMINUS_TOKEN 0xA9
#define _ARRAY_POST_MINUSMINUS_TOKEN 0xAA
#define _SCALAR_ASSIGN_TOKEN 0xB0
#define _SCALAR_PLUSEQS_TOKEN 0xB1
#define _SCALAR_MINUSEQS_TOKEN 0xB2
#define _SCALAR_TIMESEQS_TOKEN 0xB3
#define _SCALAR_DIVEQS_TOKEN 0xB4
#define _SCALAR_BOREQS_TOKEN 0xB5
#define _SCALAR_BANDEQS_TOKEN 0xB6
#define _SCALAR_PLUSPLUS_TOKEN 0xB7
#define _SCALAR_POST_PLUSPLUS_TOKEN 0xB8
#define _SCALAR_MINUSMINUS_TOKEN 0xB9
#define _SCALAR_POST_MINUSMINUS_TOKEN 0xBA
#define _DEREF_ASSIGN_TOKEN 0xC0
#define _DEREF_PLUSEQS_TOKEN 0xC1
#define _DEREF_MINUSEQS_TOKEN 0xC2
#define _DEREF_TIMESEQS_TOKEN 0xC3
#define _DEREF_DIVEQS_TOKEN 0xC4
#define _DEREF_BOREQS_TOKEN 0xC5
#define _DEREF_BANDEQS_TOKEN 0xC6
#define _DEREF_PLUSPLUS_TOKEN 0xC7
#define _DEREF_POST_PLUSPLUS_TOKEN 0xC8
#define _DEREF_MINUSMINUS_TOKEN 0xC9
#define _DEREF_POST_MINUSMINUS_TOKEN 0xCA
#define LAST_ASSIGN_TOKEN 0xCA
#define IS_ASSIGN_TOKEN(t) (((t)>=FIRST_ASSIGN_TOKEN)&&((t)<=LAST_ASSIGN_TOKEN))
#define _INLINE_ARRAY_TOKEN 0xE0
#define _INLINE_IMPLICIT_ARRAY_TOKEN 0xE1
#define _NULL_TOKEN 0xE2
#define _INLINE_WILDCARD_ARRAY_TOKEN 0xE3
#define _INLINE_LIST_TOKEN 0xE4
#define BOS_TOKEN 0xFA
#define EOS_TOKEN 0xFB
#define LINE_NUM_TOKEN 0xFC
#define ARG_TOKEN 0xFD
#define EARG_TOKEN 0xFE
#define NO_OP_LITERAL 0xFF
typedef struct
{
/* sltoken.c */
/* SLang_eval_object */
SLang_Load_Type *llt;
SLprep_Type *this_slpp;
/* prep_get_char() */
char *input_line;
char cchar;
/* get_token() */
int want_nl_token;
/* slparse.c */
_pSLang_Token_Type ctok;
int block_depth;
int assignment_expression;
/* slang.c : SLcompile() */
_pSLang_Token_Type save_token;
_pSLang_Token_Type next_token;
void (*slcompile_ptr)(_pSLang_Token_Type *);
}
_pSLEval_Context;
extern int _pSLget_token (_pSLang_Token_Type *);
extern void _pSLparse_error (int, char *, _pSLang_Token_Type *, int);
extern void _pSLparse_start (SLang_Load_Type *);
extern int _pSLget_rpn_token (_pSLang_Token_Type *);
extern void _pSLcompile_byte_compiled (void);
extern int (*_pSLprep_eval_hook) (char *);
extern int _pSLsecure_issetugid (void);
extern char *_pSLsecure_getenv (char *);
/* Error Handling */
extern int _pSLang_init_exceptions (void);
extern int _pSLerr_init (void);
extern void _pSLerr_deinit (void);
extern int _pSLerr_suspend_messages (void);
extern int _pSLerr_resume_messages (void);
extern int _pSLerr_traceback_msg (char *, ...) SLATTRIBUTE_PRINTF(1,2);
extern void _pSLerr_dump_msg (char *, ...) SLATTRIBUTE_PRINTF(1,2);
extern void _pSLerr_clear_error (void);
extern void _pSLerr_print_message_queue (void);
extern int _pSLerr_set_line_info (char *, int, char *);
extern int _pSLang_pop_error_context (void);
extern int _pSLang_push_error_context (void);
extern void (*_pSLinterpreter_Error_Hook)(int);
extern int _pSLerr_init_interp_exceptions (void);
extern int _pSLerr_get_last_error (void);
extern int _pSLerr_pop_exception (int *);
extern void _pSLerr_free_queued_messages (void);
extern char *_pSLerr_get_error_from_queue (void);
extern int _pSLerr_throw (void);
extern int (*_pSLerr_New_Exception_Hook)(char *name, char *desc, int error_code);
#if SLANG_HAS_DEBUGGER_SUPPORT
typedef struct
{
char **locals;
unsigned int nlocals;
char *file;
unsigned int line;
char *function;
char *ns;
}
_pSLang_Frame_Info_Type;
extern int _pSLang_get_frame_fun_info (int depth, _pSLang_Frame_Info_Type *info);
extern int _pSLang_set_frame_variable (int depth, char *name);
extern int _pSLang_get_frame_variable (int depth, char *name);
extern void _pSLang_use_frame_namespace (int depth);
extern int _pSLang_get_frame_depth (void);
#endif
#if SLANG_HAS_FLOAT
extern int _pSLmath_isnan (double x);
#endif
#if SLANG_HAS_SIGNALS
extern void _pSLang_signal_interrupt (void);
extern int _pSLsig_block_and_call (int (*)(VOID_STAR), VOID_STAR);
extern int _pSLsig_handle_signals (void);
extern int _pSLang_check_signals_hook (VOID_STAR);
#else
#define _pSLsig_block_and_call(f,v) f(v)
#endif
#undef _INLINE_
#if defined(__GNUC__) && SLANG_USE_INLINE_CODE
# define _INLINE_ __inline__
#else
# define _INLINE_
#endif
/* This is a macro that permits:
*
* extern fun (void **addr);
* double x;
* fun ((void **) &x); <--- warning
* fun (VOID_STAR_STAR(&x));
*
* Otherwise a type-punning warning could result due to strict-aliasing.
*/
#define VOID_STAR_STAR(addr) (VOID_STAR *)(VOID_STAR)(addr)
#endif /* PRIVATE_SLANG_H_ */