src/lj_tab.h - luajit-2.0-src

Functions defined

Macros defined

Source code

  1. /*
  2. ** Table handling.
  3. ** Copyright (C) 2005-2015 Mike Pall. See Copyright Notice in luajit.h
  4. */

  5. #ifndef _LJ_TAB_H
  6. #define _LJ_TAB_H

  7. #include "lj_obj.h"

  8. /* Hash constants. Tuned using a brute force search. */
  9. #define HASH_BIAS        (-0x04c11db7)
  10. #define HASH_ROT1        14
  11. #define HASH_ROT2        5
  12. #define HASH_ROT3        13

  13. /* Scramble the bits of numbers and pointers. */
  14. static LJ_AINLINE uint32_t hashrot(uint32_t lo, uint32_t hi)
  15. {
  16. #if LJ_TARGET_X86ORX64
  17.   /* Prefer variant that compiles well for a 2-operand CPU. */
  18.   lo ^= hi; hi = lj_rol(hi, HASH_ROT1);
  19.   lo -= hi; hi = lj_rol(hi, HASH_ROT2);
  20.   hi ^= lo; hi -= lj_rol(lo, HASH_ROT3);
  21. #else
  22.   lo ^= hi;
  23.   lo = lo - lj_rol(hi, HASH_ROT1);
  24.   hi = lo ^ lj_rol(hi, HASH_ROT1 + HASH_ROT2);
  25.   hi = hi - lj_rol(lo, HASH_ROT3);
  26. #endif
  27.   return hi;
  28. }

  29. #define hsize2hbits(s)        ((s) ? ((s)==1 ? 1 : 1+lj_fls((uint32_t)((s)-1))) : 0)

  30. LJ_FUNCA GCtab *lj_tab_new(lua_State *L, uint32_t asize, uint32_t hbits);
  31. LJ_FUNC GCtab *lj_tab_new_ah(lua_State *L, int32_t a, int32_t h);
  32. #if LJ_HASJIT
  33. LJ_FUNC GCtab * LJ_FASTCALL lj_tab_new1(lua_State *L, uint32_t ahsize);
  34. #endif
  35. LJ_FUNCA GCtab * LJ_FASTCALL lj_tab_dup(lua_State *L, const GCtab *kt);
  36. LJ_FUNC void LJ_FASTCALL lj_tab_clear(GCtab *t);
  37. LJ_FUNC void LJ_FASTCALL lj_tab_free(global_State *g, GCtab *t);
  38. #if LJ_HASFFI
  39. LJ_FUNC void lj_tab_rehash(lua_State *L, GCtab *t);
  40. #endif
  41. LJ_FUNCA void lj_tab_reasize(lua_State *L, GCtab *t, uint32_t nasize);

  42. /* Caveat: all getters except lj_tab_get() can return NULL! */

  43. LJ_FUNCA cTValue * LJ_FASTCALL lj_tab_getinth(GCtab *t, int32_t key);
  44. LJ_FUNC cTValue *lj_tab_getstr(GCtab *t, GCstr *key);
  45. LJ_FUNCA cTValue *lj_tab_get(lua_State *L, GCtab *t, cTValue *key);

  46. /* Caveat: all setters require a write barrier for the stored value. */

  47. LJ_FUNCA TValue *lj_tab_newkey(lua_State *L, GCtab *t, cTValue *key);
  48. LJ_FUNCA TValue *lj_tab_setinth(lua_State *L, GCtab *t, int32_t key);
  49. LJ_FUNC TValue *lj_tab_setstr(lua_State *L, GCtab *t, GCstr *key);
  50. LJ_FUNC TValue *lj_tab_set(lua_State *L, GCtab *t, cTValue *key);

  51. #define inarray(t, key)                ((MSize)(key) < (MSize)(t)->asize)
  52. #define arrayslot(t, i)                (&tvref((t)->array)[(i)])
  53. #define lj_tab_getint(t, key) \
  54.   (inarray((t), (key)) ? arrayslot((t), (key)) : lj_tab_getinth((t), (key)))
  55. #define lj_tab_setint(L, t, key) \
  56.   (inarray((t), (key)) ? arrayslot((t), (key)) : lj_tab_setinth(L, (t), (key)))

  57. LJ_FUNCA int lj_tab_next(lua_State *L, GCtab *t, TValue *key);
  58. LJ_FUNCA MSize LJ_FASTCALL lj_tab_len(GCtab *t);

  59. #endif