llimits.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /*
  2. ** $Id: llimits.h,v 1.44 2002/06/13 13:45:31 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. /* an integer big enough to count the number of steps when calling a
  43. ** `count' hook */
  44. typedef long ls_count;
  45. /* chars used as small naturals (so that `char' is reserved for characteres) */
  46. typedef unsigned char lu_byte;
  47. #define MAX_SIZET ((size_t)(~(size_t)0)-2)
  48. #define MAX_INT (INT_MAX-2) /* maximum value of an int (-2 for safety) */
  49. /*
  50. ** conversion of pointer to integer
  51. ** this is for hashing only; there is no problem if the integer
  52. ** cannot hold the whole pointer value
  53. */
  54. #define IntPoint(p) ((lu_hash)(p))
  55. /* type to ensure maximum alignment */
  56. #ifndef LUSER_ALIGNMENT_T
  57. #define LUSER_ALIGNMENT_T double
  58. #endif
  59. union L_Umaxalign { LUSER_ALIGNMENT_T u; void *s; long l; };
  60. #ifndef lua_assert
  61. #define lua_assert(c) /* empty */
  62. #endif
  63. #ifndef check_exp
  64. #define check_exp(c,e) (e)
  65. #endif
  66. #ifndef UNUSED
  67. #define UNUSED(x) ((void)(x)) /* to avoid warnings */
  68. #endif
  69. #ifndef cast
  70. #define cast(t, exp) ((t)(exp))
  71. #endif
  72. /*
  73. ** type for virtual-machine instructions
  74. ** must be an unsigned with (at least) 4 bytes (see details in lopcodes.h)
  75. */
  76. typedef unsigned long Instruction;
  77. /* maximum depth for calls */
  78. #ifndef LUA_MAXCALLS
  79. #define LUA_MAXCALLS 4096
  80. #endif
  81. /* maximum size for the C stack */
  82. #ifndef LUA_MAXCSTACK
  83. #define LUA_MAXCSTACK 2048
  84. #endif
  85. /* maximum stack for a Lua function */
  86. #define MAXSTACK 250
  87. /* maximum number of variables declared in a function */
  88. #ifndef MAXVARS
  89. #define MAXVARS 200 /* arbitrary limit (<MAXSTACK) */
  90. #endif
  91. /* maximum number of upvalues per function */
  92. #ifndef MAXUPVALUES
  93. #define MAXUPVALUES 32
  94. #endif
  95. /* maximum number of parameters in a function */
  96. #ifndef MAXPARAMS
  97. #define MAXPARAMS 100 /* arbitrary limit (<MAXLOCALS) */
  98. #endif
  99. /* minimum size for the string table (must be power of 2) */
  100. #ifndef MINSTRTABSIZE
  101. #define MINSTRTABSIZE 32
  102. #endif
  103. #endif