llimits.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. /*
  2. ** $Id: llimits.h,v 1.50 2002/11/22 18:01:46 roberto Exp roberto $
  3. ** Limits, basic types, and some other `installation-dependent' definitions
  4. ** See Copyright Notice in lua.h
  5. */
  6. #ifndef llimits_h
  7. #define llimits_h
  8. #include <limits.h>
  9. #include <stddef.h>
  10. #include "lua.h"
  11. /*
  12. ** try to find number of bits in an integer
  13. */
  14. #ifndef BITS_INT
  15. /* avoid overflows in comparison */
  16. #if INT_MAX-20 < 32760
  17. #define BITS_INT 16
  18. #else
  19. #if INT_MAX > 2147483640L
  20. /* machine has at least 32 bits */
  21. #define BITS_INT 32
  22. #else
  23. #error "you must define BITS_INT with number of bits in an integer"
  24. #endif
  25. #endif
  26. #endif
  27. /*
  28. ** the following types define integer types for values that may not
  29. ** fit in a `small int' (16 bits), but may waste space in a
  30. ** `large long' (64 bits). The current definitions should work in
  31. ** any machine, but may not be optimal.
  32. */
  33. /* an unsigned integer to hold hash values */
  34. typedef unsigned int lu_hash;
  35. /* its signed equivalent */
  36. typedef int ls_hash;
  37. /* an unsigned integer big enough to count the total memory used by Lua; */
  38. /* it should be at least as large as size_t */
  39. typedef unsigned long lu_mem;
  40. /* an integer big enough to count the number of strings in use */
  41. typedef long ls_nstr;
  42. /* chars used as small naturals (so that `char' is reserved for characters) */
  43. typedef unsigned char lu_byte;
  44. #define MAX_SIZET ((size_t)(~(size_t)0)-2)
  45. #define MAX_INT (INT_MAX-2) /* maximum value of an int (-2 for safety) */
  46. /*
  47. ** conversion of pointer to integer
  48. ** this is for hashing only; there is no problem if the integer
  49. ** cannot hold the whole pointer value
  50. */
  51. #define IntPoint(p) ((lu_hash)(p))
  52. /* type to ensure maximum alignment */
  53. #ifndef LUSER_ALIGNMENT_T
  54. typedef union { double u; void *s; long l; } L_Umaxalign;
  55. #else
  56. typedef LUSER_ALIGNMENT_T L_Umaxalign;
  57. #endif
  58. /* result of `usual argument conversion' over lua_Number */
  59. #ifndef LUA_UACNUMBER
  60. typedef double l_uacNumber;
  61. #else
  62. typedef LUA_UACNUMBER l_uacNumber;
  63. #endif
  64. #ifndef lua_assert
  65. #define lua_assert(c) /* empty */
  66. #endif
  67. #ifndef check_exp
  68. #define check_exp(c,e) (e)
  69. #endif
  70. #ifndef UNUSED
  71. #define UNUSED(x) ((void)(x)) /* to avoid warnings */
  72. #endif
  73. #ifndef cast
  74. #define cast(t, exp) ((t)(exp))
  75. #endif
  76. /*
  77. ** type for virtual-machine instructions
  78. ** must be an unsigned with (at least) 4 bytes (see details in lopcodes.h)
  79. */
  80. typedef unsigned long Instruction;
  81. /* maximum depth for calls (unsigned short) */
  82. #ifndef LUA_MAXCALLS
  83. #define LUA_MAXCALLS 4096
  84. #endif
  85. /*
  86. ** maximum depth for C calls (unsigned short): Not too big, or may
  87. ** overflow the C stack...
  88. */
  89. #ifndef LUA_MAXCCALLS
  90. #define LUA_MAXCCALLS 200
  91. #endif
  92. /* maximum size for the C stack */
  93. #ifndef LUA_MAXCSTACK
  94. #define LUA_MAXCSTACK 2048
  95. #endif
  96. /* maximum stack for a Lua function */
  97. #define MAXSTACK 250
  98. /* maximum number of variables declared in a function */
  99. #ifndef MAXVARS
  100. #define MAXVARS 200 /* arbitrary limit (<MAXSTACK) */
  101. #endif
  102. /* maximum number of upvalues per function */
  103. #ifndef MAXUPVALUES
  104. #define MAXUPVALUES 32
  105. #endif
  106. /* maximum number of parameters in a function */
  107. #ifndef MAXPARAMS
  108. #define MAXPARAMS 100 /* arbitrary limit (<MAXLOCALS) */
  109. #endif
  110. /* minimum size for the string table (must be power of 2) */
  111. #ifndef MINSTRTABSIZE
  112. #define MINSTRTABSIZE 32
  113. #endif
  114. /* minimum size for string buffer */
  115. #ifndef LUA_MINBUFFER
  116. #define LUA_MINBUFFER 32
  117. #endif
  118. /*
  119. ** maximum number of syntactical nested non-terminals: Not too big,
  120. ** or may overflow the C stack...
  121. */
  122. #ifndef LUA_MAXPARSERLEVEL
  123. #define LUA_MAXPARSERLEVEL 200
  124. #endif
  125. #endif