summaryrefslogtreecommitdiff
path: root/src/lib_ffi.c
diff options
context:
space:
mode:
authorMike Pall <mike>2011-02-07 23:49:27 +0100
committerMike Pall <mike>2011-02-07 23:49:27 +0100
commit7a37b93f1b40ba83cc68965b1c80c35363c1493d (patch)
treed60ad18e47839b3998e1191672249735c46a99cc /src/lib_ffi.c
parentfb53d4aeb7590e0e8437b03589ef68adf4611570 (diff)
downloadluajit2-7a37b93f1b40ba83cc68965b1c80c35363c1493d.tar.gz
FFI: Record ffi.copy() and ffi.fill().
Diffstat (limited to 'src/lib_ffi.c')
-rw-r--r--src/lib_ffi.c26
1 files changed, 12 insertions, 14 deletions
diff --git a/src/lib_ffi.c b/src/lib_ffi.c
index 53dd50a9..45065c12 100644
--- a/src/lib_ffi.c
+++ b/src/lib_ffi.c
@@ -455,29 +455,27 @@ LJLIB_CF(ffi_string) LJLIB_REC(.)
return 1;
}
-LJLIB_CF(ffi_copy)
+LJLIB_CF(ffi_copy) LJLIB_REC(.)
{
void *dp = ffi_checkptr(L, 1, CTID_P_VOID);
void *sp = ffi_checkptr(L, 2, CTID_P_CVOID);
TValue *o = L->base+1;
- CTSize sz;
- if (tvisstr(o) && o+1 >= L->top) {
- sz = strV(o)->len+1; /* Copy Lua string including trailing '\0'. */
- } else {
- sz = (CTSize)ffi_checkint(L, 3);
- if (tvisstr(o) && sz > strV(o)->len+1)
- sz = strV(o)->len+1; /* Max. copy length is string length. */
- }
- memcpy(dp, sp, sz);
+ CTSize len;
+ if (tvisstr(o) && o+1 >= L->top)
+ len = strV(o)->len+1; /* Copy Lua string including trailing '\0'. */
+ else
+ len = (CTSize)ffi_checkint(L, 3);
+ memcpy(dp, sp, len);
return 0;
}
-LJLIB_CF(ffi_fill)
+LJLIB_CF(ffi_fill) LJLIB_REC(.)
{
void *dp = ffi_checkptr(L, 1, CTID_P_VOID);
- CTSize sz = (CTSize)ffi_checkint(L, 2);
- int32_t fill = lj_lib_optint(L, 3, 0);
- memset(dp, fill, sz);
+ CTSize len = (CTSize)ffi_checkint(L, 2);
+ int32_t fill = 0;
+ if (L->base+2 < L->top && !tvisnil(L->base+2)) fill = ffi_checkint(L, 3);
+ memset(dp, fill, len);
return 0;
}