llimits.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. /*
  2. ** $Id: llimits.h,v 1.29 2001/06/05 18:17:01 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. typedef unsigned long lu_mem;
  39. /* an integer big enough to count the number of strings in use */
  40. typedef long ls_nstr;
  41. /* chars used as small naturals (so that `char' is reserved for characteres) */
  42. typedef unsigned char lu_byte;
  43. #define MAX_SIZET ((size_t)(~(size_t)0)-2)
  44. #define MAX_INT (INT_MAX-2) /* maximum value of an int (-2 for safety) */
  45. /*
  46. ** conversion of pointer to integer
  47. ** this is for hashing only; there is no problem if the integer
  48. ** cannot hold the whole pointer value
  49. ** (the shift removes bits that are usually 0 because of alignment)
  50. */
  51. #define IntPoint(p) ((((lu_hash)(p)) >> 4) ^ (lu_hash)(p))
  52. #define MINPOWER2 4 /* minimum size for `growing' vectors */
  53. #ifndef DEFAULT_STACK_SIZE
  54. #define DEFAULT_STACK_SIZE 1024
  55. #endif
  56. /* type to ensure maximum alignment */
  57. #ifndef LUSER_ALIGNMENT_T
  58. #define LUSER_ALIGNMENT_T double
  59. #endif
  60. union L_Umaxalign { LUSER_ALIGNMENT_T u; void *s; long l; };
  61. /*
  62. ** type for virtual-machine instructions
  63. ** must be an unsigned with (at least) 4 bytes (see details in lopcodes.h)
  64. */
  65. typedef unsigned long Instruction;
  66. /* maximum stack for a Lua function */
  67. #define MAXSTACK 250
  68. /* maximum number of local variables */
  69. #ifndef MAXLOCALS
  70. #define MAXLOCALS 200 /* arbitrary limit (<MAXSTACK) */
  71. #endif
  72. /* maximum number of upvalues */
  73. #ifndef MAXUPVALUES
  74. #define MAXUPVALUES 32 /* arbitrary limit (<MAXSTACK) */
  75. #endif
  76. /* maximum number of parameters in a function */
  77. #ifndef MAXPARAMS
  78. #define MAXPARAMS 100 /* arbitrary limit (<MAXLOCALS) */
  79. #endif
  80. /* number of list items to accumulate before a SETLIST instruction */
  81. /* (must be a power of 2) */
  82. #define LFIELDS_PER_FLUSH 64
  83. /* maximum lookback to find a real constant (for code generation) */
  84. #ifndef LOOKBACKNUMS
  85. #define LOOKBACKNUMS 40 /* arbitrary constant */
  86. #endif
  87. #endif