|
@@ -1,5 +1,5 @@
|
|
|
/*
|
|
|
-** $Id: lvm.h,v 2.37 2015/08/03 19:50:49 roberto Exp roberto $
|
|
|
+** $Id: lvm.h,v 2.38 2015/08/03 20:40:26 roberto Exp roberto $
|
|
|
** Lua virtual machine
|
|
|
** See Copyright Notice in lua.h
|
|
|
*/
|
|
@@ -70,17 +70,27 @@
|
|
|
else luaV_finishget(L,t,k,v,aux); }
|
|
|
|
|
|
|
|
|
-#define luaV_fastset(L,t,k,aux,f,v) \
|
|
|
+/*
|
|
|
+** Fast track for set table. If 't' is a table and 't[k]' is not nil,
|
|
|
+** call GC barrier, do a raw 't[k]=v', and return true; otherwise,
|
|
|
+** return false with 'slot' equal to NULL (if 't' is not a table) or
|
|
|
+** 'nil'. (This is needed by 'luaV_finishget'.) Note that, if the macro
|
|
|
+** returns true, there is no need to 'invalidateTMcache', because the
|
|
|
+** call is not creating a new entry.
|
|
|
+*/
|
|
|
+#define luaV_fastset(L,t,k,slot,f,v) \
|
|
|
(!ttistable(t) \
|
|
|
- ? (aux = NULL, 0) \
|
|
|
- : (aux = f(hvalue(t), k), \
|
|
|
- ttisnil(aux) ? 0 \
|
|
|
- : (luaC_barrierback(L, hvalue(t), v), 1)))
|
|
|
-
|
|
|
-#define luaV_settable(L,t,k,v) { const TValue *aux; \
|
|
|
- if (luaV_fastset(L,t,k,aux,luaH_get,v)) \
|
|
|
- { invalidateTMcache(hvalue(t)); setobj2t(L, cast(TValue *,aux), v); } \
|
|
|
- else luaV_finishset(L,t,k,v,aux); }
|
|
|
+ ? (slot = NULL, 0) \
|
|
|
+ : (slot = f(hvalue(t), k), \
|
|
|
+ ttisnil(slot) ? 0 \
|
|
|
+ : (luaC_barrierback(L, hvalue(t), v), \
|
|
|
+ setobj2t(L, cast(TValue *,slot), v), \
|
|
|
+ 1)))
|
|
|
+
|
|
|
+
|
|
|
+#define luaV_settable(L,t,k,v) { const TValue *slot; \
|
|
|
+ if (!luaV_fastset(L,t,k,slot,luaH_get,v)) \
|
|
|
+ luaV_finishset(L,t,k,v,slot); }
|
|
|
|
|
|
|
|
|
|