summaryrefslogtreecommitdiff
path: root/source/tools
diff options
context:
space:
mode:
Diffstat (limited to 'source/tools')
-rw-r--r--source/tools/murun.c26
1 files changed, 25 insertions, 1 deletions
diff --git a/source/tools/murun.c b/source/tools/murun.c
index 12c274d1..0d208cad 100644
--- a/source/tools/murun.c
+++ b/source/tools/murun.c
@@ -2723,7 +2723,16 @@ static int ffi_pdf_obj_has(js_State *J, void *obj, const char *key)
{
fz_context *ctx = js_getcontext(J);
pdf_obj *val;
- int idx;
+ int idx, len;
+
+ if (!strcmp(key, "length")) {
+ fz_try(ctx)
+ len = pdf_array_len(ctx, obj);
+ fz_catch(ctx)
+ rethrow(J);
+ js_pushnumber(J, len);
+ return 1;
+ }
if (is_number(key, &idx)) {
fz_try(ctx)
@@ -3225,6 +3234,20 @@ static void ffi_PDFObject_delete(js_State *J)
ffi_pdf_obj_delete(J, obj, key);
}
+static void ffi_PDFObject_push(js_State *J)
+{
+ fz_context *ctx = js_getcontext(J);
+ pdf_obj *obj = js_touserdata(J, 0, "pdf_obj");
+ pdf_document *pdf = pdf_get_bound_document(ctx, obj);
+ pdf_obj *item = ffi_toobj(J, pdf, 1);
+ fz_try(ctx)
+ pdf_array_push(ctx, obj, item);
+ fz_always(ctx)
+ pdf_drop_obj(ctx, item);
+ fz_catch(ctx)
+ rethrow(J);
+}
+
static void ffi_PDFObject_resolve(js_State *J)
{
fz_context *ctx = js_getcontext(J);
@@ -3758,6 +3781,7 @@ int murun_main(int argc, char **argv)
{
jsB_propfun(J, "PDFObject.get", ffi_PDFObject_get, 0);
jsB_propfun(J, "PDFObject.put", ffi_PDFObject_put, 0);
+ jsB_propfun(J, "PDFObject.push", ffi_PDFObject_push, 0);
jsB_propfun(J, "PDFObject.delete", ffi_PDFObject_delete, 0);
jsB_propfun(J, "PDFObject.resolve", ffi_PDFObject_resolve, 0);
jsB_propfun(J, "PDFObject.toString", ffi_PDFObject_toString, 1);