diff options
-rw-r--r-- | print/ruby-gnome2-poppler/Makefile | 5 | ||||
-rw-r--r-- | print/ruby-gnome2-poppler/PLIST | 6 | ||||
-rw-r--r-- | print/ruby-gnome2-poppler/distinfo | 7 | ||||
-rw-r--r-- | print/ruby-gnome2-poppler/patches/patch-aa | 32 | ||||
-rw-r--r-- | print/ruby-gnome2-poppler/patches/patch-ab | 840 |
5 files changed, 4 insertions, 886 deletions
diff --git a/print/ruby-gnome2-poppler/Makefile b/print/ruby-gnome2-poppler/Makefile index 775fe288c68..e4add9ca194 100644 --- a/print/ruby-gnome2-poppler/Makefile +++ b/print/ruby-gnome2-poppler/Makefile @@ -1,17 +1,14 @@ -# $NetBSD: Makefile,v 1.2 2007/11/11 23:30:17 wiz Exp $ +# $NetBSD: Makefile,v 1.3 2008/06/19 15:14:15 taca Exp $ # PKGNAME= ${RUBY_PKGPREFIX}-gnome2-poppler-${VERSION} -PKGREVISION= 1 COMMENT= Ruby binding of poppler-glib CATEGORIES= print RUBY_EXTCONF_SUBDIRS= poppler -DEPENDS+= ${RUBY_PKGPREFIX}-gnome2-glib>=${VERSION}:../../devel/ruby-gnome2-glib DEPENDS+= ${RUBY_PKGPREFIX}-gnome2-gdkpixbuf>=${VERSION}:../../graphics/ruby-gnome2-gdkpixbuf USE_TOOLS+= pkg-config -DISTINFO_FILE?= ${.CURDIR}/distinfo BUILDLINK_API_DEPENDS.poppler-glib+= poppler-glib>=0.6.0 diff --git a/print/ruby-gnome2-poppler/PLIST b/print/ruby-gnome2-poppler/PLIST index 672c3015ac7..82e5c9e2e54 100644 --- a/print/ruby-gnome2-poppler/PLIST +++ b/print/ruby-gnome2-poppler/PLIST @@ -1,3 +1,3 @@ -@comment $NetBSD: PLIST,v 1.1.1.1 2007/05/27 02:00:02 obache Exp $ -${RUBY_SITELIBDIR}/poppler.rb -${RUBY_SITEARCHLIBDIR}/poppler.${RUBY_DLEXT} +@comment $NetBSD: PLIST,v 1.2 2008/06/19 15:14:15 taca Exp $ +${RUBY_VENDORLIB}/poppler.rb +${RUBY_VENDORARCHLIB}/poppler.${RUBY_DLEXT} diff --git a/print/ruby-gnome2-poppler/distinfo b/print/ruby-gnome2-poppler/distinfo deleted file mode 100644 index a4dd168d379..00000000000 --- a/print/ruby-gnome2-poppler/distinfo +++ /dev/null @@ -1,7 +0,0 @@ -$NetBSD: distinfo,v 1.1 2007/11/11 23:30:17 wiz Exp $ - -SHA1 (ruby-gnome2-all-0.16.0.tar.gz) = 488f6c1f139060e005f336c9c854c4dc5b3e6b7c -RMD160 (ruby-gnome2-all-0.16.0.tar.gz) = c83c7cdcf633ad5cc213180f641a6c8f18002a9c -Size (ruby-gnome2-all-0.16.0.tar.gz) = 1208856 bytes -SHA1 (patch-aa) = e304eae9b1341db74e5bcc7e8aa51f3e6475b4fa -SHA1 (patch-ab) = 82c0981b80df1dd5390f53561e510bf9e32575d0 diff --git a/print/ruby-gnome2-poppler/patches/patch-aa b/print/ruby-gnome2-poppler/patches/patch-aa deleted file mode 100644 index 6a3d83700ba..00000000000 --- a/print/ruby-gnome2-poppler/patches/patch-aa +++ /dev/null @@ -1,32 +0,0 @@ -$NetBSD: patch-aa,v 1.1 2007/11/11 23:30:18 wiz Exp $ - ---- poppler/src/rbpoppler.h.orig 2006-12-29 14:17:28.000000000 +0100 -+++ poppler/src/rbpoppler.h -@@ -38,16 +38,27 @@ extern GType poppler_dest_get_type (void - #define REGION2RVAL(obj) (BOXED2RVAL(obj, GDK_TYPE_REGION)) - #define RVAL2DEST(obj) ((PopplerDest *)RVAL2BOXED(obj, POPPLER_TYPE_DEST)) - #define DEST2RVAL(obj) (BOXED2RVAL(obj, POPPLER_TYPE_DEST)) -+#define TRANS2RVAL(obj) (BOXED2RVAL(obj, POPPLER_TYPE_PAGE_TRANSITION)) -+#define RVAL2TRANS(obj) ((PopplerPageTransition *)RVAL2BOXED(obj, POPPLER_TYPE_PAGE_TRANSITION)) -+ - #define DESTTYPE2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_DEST_TYPE)) - #define ACTIONTYPE2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_ACTION_TYPE)) - #define RVAL2ACTIONTYPE(obj) (RVAL2GENUM(obj, POPPLER_TYPE_ACTION_TYPE)) -+#define SELSTYLE2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_SELECTION_STYLE)) -+#define RVAL2SELSTYLE(obj) (RVAL2GENUM(obj, POPPLER_TYPE_SELECTION_STYLE)) - #define RVAL2COLOR(obj) ((GdkColor *)RVAL2BOXED(obj, GDK_TYPE_COLOR)) - - #define ACTION2RVAL(obj) (rb_poppler_ruby_object_from_action(obj)) - #define RVAL2ACTION(obj) (rb_poppler_action_from_ruby_object(obj)) -+#define FF2RVAL(obj) (rb_poppler_ruby_object_from_form_field(obj)) - - extern VALUE rb_poppler_ruby_object_from_action(PopplerAction *action); - extern PopplerAction *rb_poppler_action_from_ruby_object(VALUE action); -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+extern VALUE rb_poppler_ruby_object_from_form_field(PopplerFormField *field); -+#endif -+ -+#define RVAL2GDK_PIXBUF(pixbuf) (GDK_PIXBUF(RVAL2GOBJ(pixbuf))) - - - extern void Init_poppler_document(VALUE mPoppler); diff --git a/print/ruby-gnome2-poppler/patches/patch-ab b/print/ruby-gnome2-poppler/patches/patch-ab deleted file mode 100644 index 84806fe5be7..00000000000 --- a/print/ruby-gnome2-poppler/patches/patch-ab +++ /dev/null @@ -1,840 +0,0 @@ -$NetBSD: patch-ab,v 1.1 2007/11/11 23:30:18 wiz Exp $ - ---- poppler/src/rbpoppler-page.c.orig 2006-12-29 14:17:28.000000000 +0100 -+++ poppler/src/rbpoppler-page.c -@@ -12,16 +12,39 @@ - - #include "rbpoppler.h" - -+#define SELF(self) (POPPLER_PAGE(RVAL2GOBJ(self))) - #define RVAL2LM(obj) ((PopplerLinkMapping *)RVAL2BOXED(obj, POPPLER_TYPE_LINK_MAPPING)) -+#define RVAL2IM(obj) ((PopplerImageMapping *)RVAL2BOXED(obj, POPPLER_TYPE_IMAGE_MAPPING)) -+#define RVAL2FFM(obj) ((PopplerFormFieldMapping *)RVAL2BOXED(obj, POPPLER_TYPE_FORM_FIELD_MAPPING)) -+#define RVAL2FF(obj) (POPPLER_FORM_FIELD(RVAL2GOBJ(obj))) -+#define RVAL2TF(obj) RVAL2FF(obj) -+#define RVAL2BF(obj) RVAL2FF(obj) -+#define RVAL2CF(obj) RVAL2FF(obj) -+ -+#define TT2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_PAGE_TRANSITION_TYPE)) -+#define RVAL2TT(obj) (RVAL2GENUM(obj, POPPLER_TYPE_PAGE_TRANSITION_TYPE)) -+#define TA2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_PAGE_TRANSITION_ALIGNMENT)) -+#define RVAL2TA(obj) (RVAL2GENUM(obj, POPPLER_TYPE_PAGE_TRANSITION_ALIGNMENT)) -+#define TD2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_PAGE_TRANSITION_DIRECTION)) -+#define RVAL2TD(obj) (RVAL2GENUM(obj, POPPLER_TYPE_PAGE_TRANSITION_DIRECTION)) -+#define FFT2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_FORM_FIELD_TYPE)) -+#define RVAL2FFT(obj) (RVAL2GENUM(obj, POPPLER_TYPE_FORM_FIELD_TYPE)) -+#define FBT2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_FORM_BUTTON_TYPE)) -+#define FTT2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_FORM_TEXT_TYPE)) -+#define FCT2RVAL(obj) (GENUM2RVAL(obj, POPPLER_TYPE_FORM_CHOICE_TYPE)) - --static VALUE cPSFile; -+static VALUE cPSFile, cRectangle; -+ -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+VALUE cUnknownField, cTextField, cButtonField, cChoiceField, cSignatureField; -+#endif - - static VALUE - page_render_to_pixbuf(VALUE self, VALUE src_x, VALUE src_y, VALUE src_width, - VALUE src_height, VALUE scale, VALUE rotation, - VALUE pixbuf) - { -- poppler_page_render_to_pixbuf(RVAL2GOBJ(self), NUM2INT(src_x), -+ poppler_page_render_to_pixbuf(SELF(self), NUM2INT(src_x), - NUM2INT(src_y), NUM2INT(src_width), - NUM2INT(src_height), NUM2DBL(scale), - NUM2INT(rotation), RVAL2GOBJ(pixbuf)); -@@ -32,7 +55,7 @@ page_render_to_pixbuf(VALUE self, VALUE - static VALUE - page_render(VALUE self, VALUE cairo) - { -- poppler_page_render(RVAL2GOBJ(self), RVAL2CRCONTEXT(cairo)); -+ poppler_page_render(SELF(self), RVAL2CRCONTEXT(cairo)); - return Qnil; - } - #endif -@@ -40,7 +63,7 @@ page_render(VALUE self, VALUE cairo) - static VALUE - page_render_to_ps(VALUE self, VALUE ps_file) - { -- poppler_page_render_to_ps(RVAL2GOBJ(self), RVAL2GOBJ(ps_file)); -+ poppler_page_render_to_ps(SELF(self), RVAL2GOBJ(ps_file)); - return Qnil; - } - -@@ -48,7 +71,7 @@ static VALUE - page_render_generic(int argc, VALUE *argv, VALUE self) - { - if (argc == 1) { -- if (RTEST(rb_obj_is_kind_of(argv[0], cPSFile))) { -+ if (RVAL2CBOOL(rb_obj_is_kind_of(argv[0], cPSFile))) { - return page_render_to_ps(self, argv[0]); - } else { - #ifdef RB_POPPLER_CAIRO_AVAILABLE -@@ -70,20 +93,34 @@ static VALUE - page_get_size(VALUE self) - { - double width, height; -- poppler_page_get_size(RVAL2GOBJ(self), &width, &height); -+ poppler_page_get_size(SELF(self), &width, &height); - return rb_ary_new3(2, rb_float_new(width), rb_float_new(height)); - } - - static VALUE - page_get_index(VALUE self) - { -- return INT2NUM(poppler_page_get_index(RVAL2GOBJ(self))); -+ return INT2NUM(poppler_page_get_index(SELF(self))); -+} -+ -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+static VALUE -+page_get_duration(VALUE self) -+{ -+ return rb_float_new(poppler_page_get_duration(SELF(self))); - } - - static VALUE -+page_get_transition(VALUE self) -+{ -+ return TRANS2RVAL(poppler_page_get_transition(SELF(self))); -+} -+#endif -+ -+static VALUE - page_get_thumbnail(VALUE self) - { -- return GOBJ2RVAL(poppler_page_get_thumbnail(RVAL2GOBJ(self))); -+ return GOBJ2RVAL(poppler_page_get_thumbnail(SELF(self))); - } - - static VALUE -@@ -91,7 +128,7 @@ page_get_thumbnail_size(VALUE self) - { - int width, height; - -- if (poppler_page_get_thumbnail_size(RVAL2GOBJ(self), &width, &height)) -+ if (poppler_page_get_thumbnail_size(SELF(self), &width, &height)) - return rb_ary_new3(2, INT2NUM(width), INT2NUM(height)); - else - return Qnil; -@@ -100,17 +137,60 @@ page_get_thumbnail_size(VALUE self) - static VALUE - page_find_text(VALUE self, VALUE text) - { -- return GLIST2ARY2F(poppler_page_find_text(RVAL2GOBJ(self), RVAL2CSTR(text)), -+ return GLIST2ARY2F(poppler_page_find_text(SELF(self), RVAL2CSTR(text)), - POPPLER_TYPE_RECTANGLE); - } - - static VALUE --page_get_text(VALUE self, VALUE rect) -+page_get_text(int argc, VALUE *argv, VALUE self) - { - gchar *text; -- VALUE rb_text; -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ PopplerSelectionStyle style = POPPLER_SELECTION_GLYPH; -+#endif -+ VALUE rb_text, arg1, arg2, rb_rect; -+ PopplerPage *page; -+ -+ rb_scan_args(argc, argv, "02", &arg1, &arg2); -+ -+ page = SELF(self); -+ if (NIL_P(arg1)) { -+ rb_rect = arg2; -+ } else { -+ if (RTEST(rb_obj_is_kind_of(arg2, cRectangle))) { -+ rb_rect = arg2; -+ } else { -+ rb_rect = Qnil; -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ if (!NIL_P(arg2)) { -+ style = RVAL2SELSTYLE(arg2); -+ } -+#endif -+ } -+ } -+ -+ if (NIL_P(rb_rect)) { -+ PopplerRectangle rect; -+ double width, height; -+ -+ rect.x1 = 0; -+ rect.y1 = 0; -+ poppler_page_get_size(page, &width, &height); -+ rect.x2 = width; -+ rect.y2 = height; -+ text = poppler_page_get_text(page, -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ style, -+#endif -+ &rect); -+ } else { -+ text = poppler_page_get_text(page, -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ style, -+#endif -+ RVAL2RECT(rb_rect)); -+ } - -- text = poppler_page_get_text(RVAL2GOBJ(self), RVAL2RECT(rect)); - rb_text = CSTR2RVAL(text); - g_free(text); - return rb_text; -@@ -119,15 +199,50 @@ page_get_text(VALUE self, VALUE rect) - static VALUE - page_get_link_mapping(VALUE self) - { -- return GLIST2ARY2F(poppler_page_get_link_mapping(RVAL2GOBJ(self)), -+ return GLIST2ARY2F(poppler_page_get_link_mapping(SELF(self)), - POPPLER_TYPE_LINK_MAPPING); - } - -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+static VALUE -+page_get_image_mapping(VALUE self) -+{ -+ return GLIST2ARY2F(poppler_page_get_image_mapping(SELF(self)), -+ POPPLER_TYPE_IMAGE_MAPPING); -+} -+ -+static VALUE -+page_get_form_field_mapping(VALUE self) -+{ -+ return GLIST2ARY2F(poppler_page_get_form_field_mapping(SELF(self)), -+ POPPLER_TYPE_FORM_FIELD_MAPPING); -+} -+#endif -+ - static VALUE --page_get_selection_region(VALUE self, VALUE scale, VALUE selection) -+page_get_selection_region(int argc, VALUE *argv, VALUE self) - { -- return REGION2RVAL(poppler_page_get_selection_region(RVAL2GOBJ(self), -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ PopplerSelectionStyle style = POPPLER_SELECTION_GLYPH; -+#endif -+ VALUE arg2, arg3, scale, selection; -+ -+ rb_scan_args(argc, argv, "21", &scale, &arg2, &arg3); -+ -+ if (NIL_P(arg3)) { -+ selection = arg2; -+ } else { -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ style = RVAL2SELSTYLE(arg2); -+#endif -+ selection = arg3; -+ } -+ -+ return REGION2RVAL(poppler_page_get_selection_region(SELF(self), - NUM2DBL(scale), -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ style, -+#endif - RVAL2RECT(selection))); - } - -@@ -136,15 +251,16 @@ page_get_selection_region(VALUE self, VA - static VALUE - page_render_selection(VALUE self, VALUE cairo, - VALUE selection, VALUE rb_old_selection, -- VALUE glyph_color, VALUE background_color) -+ VALUE style, VALUE glyph_color, VALUE background_color) - { - PopplerRectangle *old_selection = NULL; - - if (!NIL_P(rb_old_selection)) - old_selection = RVAL2RECT(rb_old_selection); -- poppler_page_render_selection(RVAL2GOBJ(self), RVAL2CRCONTEXT(cairo), -+ poppler_page_render_selection(SELF(self), RVAL2CRCONTEXT(cairo), - RVAL2RECT(selection), - old_selection, -+ RVAL2SELSTYLE(style), - RVAL2COLOR(glyph_color), - RVAL2COLOR(background_color)); - return Qnil; -@@ -159,17 +275,24 @@ static VALUE - page_render_selection_to_pixbuf(VALUE self, VALUE scale, VALUE rotation, - VALUE pixbuf, VALUE selection, - VALUE rb_old_selection, -+#ifdef HAVE_POPPLER_PAGE_RENDER_SELECTION_TO_PIXBUF -+ VALUE style, -+#endif - VALUE glyph_color, VALUE background_color) - { - PopplerRectangle *old_selection = NULL; - - if (!NIL_P(rb_old_selection)) - old_selection = RVAL2RECT(rb_old_selection); -- poppler_page_render_selection_to_pixbuf(RVAL2GOBJ(self), NUM2DBL(scale), -+ poppler_page_render_selection_to_pixbuf(SELF(self), -+ NUM2DBL(scale), - NUM2INT(rotation), - RVAL2GOBJ(pixbuf), - RVAL2RECT(selection), - old_selection, -+#ifdef HAVE_POPPLER_PAGE_RENDER_SELECTION_TO_PIXBUF -+ RVAL2SELSTYLE(style), -+#endif - RVAL2COLOR(glyph_color), - RVAL2COLOR(background_color)); - return Qnil; -@@ -178,24 +301,86 @@ page_render_selection_to_pixbuf(VALUE se - static VALUE - page_render_selection_generic(int argc, VALUE *argv, VALUE self) - { -- if (argc == 5) { -+ if (argc == 6) { - #if defined(RB_POPPLER_CAIRO_AVAILABLE) && \ - defined(HAVE_POPPLER_PAGE_RENDER_SELECTION_TO_PIXBUF) - return page_render_selection(self, argv[0], argv[1], argv[2], -- argv[3], argv[4]); -+ argv[3], argv[4], argv[5]); - #else - rb_raise(rb_eArgError, "cairo is not available"); - #endif -+#ifdef HAVE_POPPLER_PAGE_RENDER_SELECTION_TO_PIXBUF -+ } else if (argc == 8) { -+ return page_render_selection_to_pixbuf(self, argv[0], argv[1], -+ argv[2], argv[3], argv[4], -+ argv[5], argv[6], argv[7]); -+#else - } else if (argc == 7) { - return page_render_selection_to_pixbuf(self, argv[0], argv[1], - argv[2], argv[3], argv[4], - argv[5], argv[6]); -+#endif - } else { - rb_raise(rb_eArgError, -- "wrong number of arguments (%d for 5 or 7)", argc); -+ "wrong number of arguments (%d for 5 or %d)", argc, -+#ifdef HAVE_POPPLER_PAGE_RENDER_SELECTION_TO_PIXBUF -+ 8 -+#else -+ 7 -+#endif -+ ); - } - } - -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+static VALUE -+page_get_crop_box(VALUE self) -+{ -+ PopplerRectangle rect; -+ -+ poppler_page_get_crop_box(SELF(self), &rect); -+ return RECT2RVAL(&rect); -+} -+#endif -+ -+ -+#define DEF_READER(prefix, name, member, self_to_c, member_to_rb) \ -+static VALUE \ -+prefix ## _get_ ## name(VALUE self) \ -+{ \ -+ return member_to_rb((self_to_c(self))->member); \ -+} -+ -+#define DEF_WRITER(prefix, name, member, self_to_c, value_to_c) \ -+static VALUE \ -+prefix ## _set_ ## name(VALUE self, VALUE value) \ -+{ \ -+ (self_to_c(self))->member = value_to_c(value); \ -+ return Qnil; \ -+} -+ -+#define DEF_WRITER_WITH_SETTER(prefix, name, member, \ -+ self_to_c, value_setter) \ -+static VALUE \ -+prefix ## _set_ ## name(VALUE self, VALUE value) \ -+{ \ -+ value_setter((self_to_c(self))->member, value); \ -+ return Qnil; \ -+} -+ -+#define DEF_ACCESSOR(prefix, member, self_to_c, member_to_rb, value_to_c) \ -+ DEF_READER(prefix, member, member, self_to_c, member_to_rb) \ -+ DEF_WRITER(prefix, member, member, self_to_c, value_to_c) \ -+ -+#define DEF_ACCESSOR_WITH_SETTER(prefix, member, self_to_c, \ -+ member_to_rb, value_setter) \ -+ DEF_READER(prefix, member, member, self_to_c, member_to_rb) \ -+ DEF_WRITER_WITH_SETTER(prefix, member, member, self_to_c, value_setter) -+ -+#define DEF_ACCESSOR_WITH_NAME(prefix, name, member, self_to_c, \ -+ member_to_rb, value_to_c) \ -+ DEF_READER(prefix, name, member, self_to_c, member_to_rb) \ -+ DEF_WRITER(prefix, name, member, self_to_c, value_to_c) - - - /* A rectangle on a page, with coordinates in PDF points. */ -@@ -213,107 +398,320 @@ rectangle_initialize(VALUE self, VALUE x - return Qnil; - } - -+DEF_ACCESSOR(rectangle, x1, RVAL2RECT, rb_float_new, NUM2DBL) -+DEF_ACCESSOR(rectangle, y1, RVAL2RECT, rb_float_new, NUM2DBL) -+DEF_ACCESSOR(rectangle, x2, RVAL2RECT, rb_float_new, NUM2DBL) -+DEF_ACCESSOR(rectangle, y2, RVAL2RECT, rb_float_new, NUM2DBL) -+ - static VALUE --rectangle_get_x1(VALUE self) -+rectangle_to_a(VALUE self) - { -- return rb_float_new(RVAL2RECT(self)->x1); -+ PopplerRectangle *rectangle = RVAL2RECT(self); -+ return rb_ary_new3(4, -+ rb_float_new(rectangle->x1), -+ rb_float_new(rectangle->y1), -+ rb_float_new(rectangle->x2), -+ rb_float_new(rectangle->y2)); - } - --static VALUE --rectangle_get_y1(VALUE self) -+ -+/* Mapping between areas on the current page and PopplerActions */ -+#define RECT_ENTITY2RVAL(rect) RECT2RVAL(&(rect)) -+#define RECT_ENTITY_SET(rect, rb_rect) rectangle_set(&(rect), rb_rect) -+static void -+rectangle_set(PopplerRectangle *rect, VALUE rb_rect) - { -- return rb_float_new(RVAL2RECT(self)->y1); -+ *rect = *(RVAL2RECT(rb_rect)); - } - --static VALUE --rectangle_get_x2(VALUE self) -+DEF_ACCESSOR_WITH_SETTER(link_mapping, area, -+ RVAL2LM, RECT_ENTITY2RVAL, RECT_ENTITY_SET) -+DEF_ACCESSOR(link_mapping, action, RVAL2LM, ACTION2RVAL, RVAL2ACTION) -+ -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ -+/* Page Transition */ -+DEF_ACCESSOR(page_trans, type, RVAL2TRANS, RVAL2TT, TT2RVAL) -+DEF_ACCESSOR(page_trans, alignment, RVAL2TRANS, RVAL2TA, TA2RVAL) -+DEF_ACCESSOR(page_trans, direction, RVAL2TRANS, RVAL2TD, TD2RVAL) -+DEF_ACCESSOR(page_trans, duration, RVAL2TRANS, NUM2INT, INT2NUM) -+DEF_ACCESSOR(page_trans, angle, RVAL2TRANS, NUM2INT, INT2NUM) -+DEF_ACCESSOR(page_trans, scale, RVAL2TRANS, NUM2DBL, rb_float_new) -+DEF_ACCESSOR(page_trans, rectangular, RVAL2TRANS, RVAL2CBOOL, CBOOL2RVAL) -+ -+ -+/* Mapping between areas on the current page and images */ -+DEF_ACCESSOR_WITH_SETTER(image_mapping, area, -+ RVAL2IM, RECT_ENTITY2RVAL, RECT_ENTITY_SET) -+DEF_ACCESSOR(image_mapping, image, RVAL2IM, GOBJ2RVAL, RVAL2GDK_PIXBUF) -+ -+ -+/* Mapping between areas on the current page and form fields */ -+VALUE -+rb_poppler_ruby_object_from_form_field(PopplerFormField *field) -+{ -+ VALUE obj; -+ -+ obj = rbgobj_ruby_object_from_instance2(field, FALSE); -+ if (NIL_P(obj)) { -+ switch (poppler_form_field_get_field_type(field)) { -+ case POPPLER_FORM_FIELD_UNKNOWN: -+ obj = rbgobj_create_object(cUnknownField); -+ break; -+ case POPPLER_FORM_FIELD_BUTTON: -+ obj = rbgobj_create_object(cButtonField); -+ break; -+ case POPPLER_FORM_FIELD_TEXT: -+ obj = rbgobj_create_object(cTextField); -+ break; -+ case POPPLER_FORM_FIELD_CHOICE: -+ obj = rbgobj_create_object(cChoiceField); -+ break; -+ case POPPLER_FORM_FIELD_SIGNATURE: -+ obj = rbgobj_create_object(cSignatureField); -+ break; -+ } -+ g_object_ref(field); -+ G_INITIALIZE(obj, (gpointer)field); -+ } -+ -+ return obj; -+} -+ -+DEF_ACCESSOR_WITH_SETTER(form_field_mapping, area, -+ RVAL2FFM, RECT_ENTITY2RVAL, RECT_ENTITY_SET) -+DEF_ACCESSOR(form_field_mapping, field, RVAL2FFM, FF2RVAL, RVAL2FF) -+ -+/* FormField */ -+VALUE -+form_field_get_id(VALUE self) - { -- return rb_float_new(RVAL2RECT(self)->x2); -+ return INT2NUM(poppler_form_field_get_id(RVAL2FF(self))); - } - --static VALUE --rectangle_get_y2(VALUE self) -+VALUE -+form_field_get_font_size(VALUE self) -+{ -+ return rb_float_new(poppler_form_field_get_font_size(RVAL2FF(self))); -+} -+ -+VALUE -+form_field_is_read_only(VALUE self) - { -- return rb_float_new(RVAL2RECT(self)->y2); -+ return CBOOL2RVAL(poppler_form_field_is_read_only(RVAL2FF(self))); - } - -+/* Button Field */ -+VALUE -+button_field_get_button_type(VALUE self) -+{ -+ return FBT2RVAL(poppler_form_field_button_get_button_type(RVAL2FF(self))); -+} - --static VALUE --rectangle_set_x1(VALUE self, VALUE x1) -+VALUE -+button_field_get_state(VALUE self) - { -- RVAL2RECT(self)->x1 = NUM2DBL(x1); -+ return CBOOL2RVAL(poppler_form_field_button_get_state(RVAL2BF(self))); -+} -+ -+VALUE -+button_field_set_state(VALUE self, VALUE state) -+{ -+ poppler_form_field_button_set_state(RVAL2BF(self), RVAL2CBOOL(state)); - return Qnil; - } - --static VALUE --rectangle_set_y1(VALUE self, VALUE y1) -+/* Text Field */ -+VALUE -+text_field_get_text_type(VALUE self) - { -- RVAL2RECT(self)->y1 = NUM2DBL(y1); -+ return FTT2RVAL(poppler_form_field_text_get_text_type(RVAL2TF(self))); -+} -+ -+VALUE -+text_field_get_text(VALUE self) -+{ -+ return CSTR2RVAL(poppler_form_field_text_get_text(RVAL2TF(self))); -+} -+ -+VALUE -+text_field_set_text(VALUE self, VALUE text) -+{ -+ poppler_form_field_text_set_text(RVAL2TF(self), RVAL2CSTR2(text)); - return Qnil; - } - --static VALUE --rectangle_set_x2(VALUE self, VALUE x2) -+VALUE -+text_field_get_max_length(VALUE self) -+{ -+ return INT2NUM(poppler_form_field_text_get_max_len(RVAL2TF(self))); -+} -+ -+VALUE -+text_field_do_spell_check(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_text_do_spell_check(RVAL2TF(self))); -+} -+ -+VALUE -+text_field_do_scroll(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_text_do_scroll(RVAL2TF(self))); -+} -+ -+VALUE -+text_field_is_rich_text(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_text_is_rich_text(RVAL2TF(self))); -+} -+ -+VALUE -+text_field_is_password(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_text_is_password(RVAL2TF(self))); -+} -+ -+ -+/* Choice Field */ -+VALUE -+choice_field_get_choice_type(VALUE self) -+{ -+ return FCT2RVAL(poppler_form_field_choice_get_choice_type(RVAL2CF(self))); -+} -+ -+VALUE -+choice_field_is_editable(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_choice_is_editable(RVAL2CF(self))); -+} -+ -+VALUE -+choice_field_can_select_multiple(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_choice_can_select_multiple(RVAL2CF(self))); -+} -+ -+VALUE -+choice_field_do_spell_check(VALUE self) - { -- RVAL2RECT(self)->x2 = NUM2DBL(x2); -+ return CBOOL2RVAL(poppler_form_field_choice_do_spell_check(RVAL2CF(self))); -+} -+ -+VALUE -+choice_field_commit_on_change(VALUE self) -+{ -+ return CBOOL2RVAL(poppler_form_field_choice_commit_on_change(RVAL2CF(self))); -+} -+ -+VALUE -+choice_field_get_n_items(VALUE self) -+{ -+ return INT2NUM(poppler_form_field_choice_get_n_items(RVAL2CF(self))); -+} -+ -+VALUE -+choice_field_get_item(VALUE self, VALUE index) -+{ -+ return CSTR2RVAL(poppler_form_field_choice_get_item(RVAL2CF(self), -+ NUM2INT(index))); -+} -+ -+VALUE -+choice_field_is_item_selected(VALUE self, VALUE index) -+{ -+ return CBOOL2RVAL(poppler_form_field_choice_is_item_selected(RVAL2CF(self), -+ NUM2INT(index))); -+} -+ -+VALUE -+choice_field_select_item(VALUE self, VALUE index) -+{ -+ poppler_form_field_choice_select_item(RVAL2CF(self), NUM2INT(index)); - return Qnil; - } - --static VALUE --rectangle_set_y2(VALUE self, VALUE y2) -+VALUE -+choice_field_unselect_all(VALUE self) - { -- RVAL2RECT(self)->y2 = NUM2DBL(y2); -+ poppler_form_field_choice_unselect_all(RVAL2CF(self)); - return Qnil; - } - --static VALUE --rectangle_to_a(VALUE self) -+VALUE -+choice_field_toggle_item(VALUE self, VALUE index) - { -- PopplerRectangle *rectangle = RVAL2RECT(self); -- return rb_ary_new3(4, -- rb_float_new(rectangle->x1), -- rb_float_new(rectangle->y1), -- rb_float_new(rectangle->x2), -- rb_float_new(rectangle->y2)); -+ poppler_form_field_choice_toggle_item(RVAL2CF(self), NUM2INT(index)); -+ return Qnil; - } - -- --/* Mapping between areas on the current page and PopplerActions */ --static VALUE --link_mapping_get_area(VALUE self) -+VALUE -+choice_field_set_text(VALUE self, VALUE text) - { -- return RECT2RVAL(&(RVAL2LM(self)->area)); -+ poppler_form_field_choice_set_text(RVAL2CF(self), RVAL2CSTR2(text)); -+ return Qnil; - } - --static VALUE --link_mapping_get_action(VALUE self) -+VALUE -+choice_field_get_text(VALUE self) - { -- return ACTION2RVAL(RVAL2LM(self)->action); -+ return CSTR2RVAL(poppler_form_field_choice_get_text(RVAL2CF(self))); - } -+#endif - - void - Init_poppler_page(VALUE mPoppler) - { -- VALUE cPage, cRectangle, cLinkMapping; -+ VALUE cPage, cLinkMapping; -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ VALUE cPageTransition, cImageMapping, cFormFieldMapping, cFormField; -+#endif - - cPage = G_DEF_CLASS(POPPLER_TYPE_PAGE, "Page", mPoppler); - cRectangle = G_DEF_CLASS(POPPLER_TYPE_RECTANGLE, "Rectangle", mPoppler); - cLinkMapping = G_DEF_CLASS(POPPLER_TYPE_LINK_MAPPING, "LinkMapping", - mPoppler); -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ cPageTransition = G_DEF_CLASS(POPPLER_TYPE_PAGE_TRANSITION, -+ "PageTransition", mPoppler); -+ cImageMapping = G_DEF_CLASS(POPPLER_TYPE_IMAGE_MAPPING, -+ "ImageMapping", mPoppler); -+ cFormFieldMapping = G_DEF_CLASS(POPPLER_TYPE_FORM_FIELD_MAPPING, -+ "FormFieldMapping", mPoppler); -+ -+ cFormField = G_DEF_CLASS(POPPLER_TYPE_FORM_FIELD, "FormField", mPoppler); -+ cUnknownField = rb_define_class_under(mPoppler, "UnknownField", cFormField); -+ cTextField = rb_define_class_under(mPoppler, "TextField", cFormField); -+ cButtonField = rb_define_class_under(mPoppler, "ButtonField", cFormField); -+ cChoiceField = rb_define_class_under(mPoppler, "ChoiceField", cFormField); -+ cSignatureField = rb_define_class_under(mPoppler, "SignatureField", -+ cFormField); -+#endif - cPSFile = rb_const_get(mPoppler, rb_intern("PSFile")); - - rb_define_method(cPage, "render", page_render_generic, -1); - rb_define_method(cPage, "size", page_get_size, 0); - rb_define_method(cPage, "index", page_get_index, 0); -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ rb_define_method(cPage, "duration", page_get_duration, 0); -+ rb_define_method(cPage, "transition", page_get_transition, 0); -+#endif - rb_define_method(cPage, "thumbnail", page_get_thumbnail, 0); - rb_define_method(cPage, "thumbnail_size", page_get_thumbnail_size, 0); - rb_define_method(cPage, "find_text", page_find_text, 1); -- rb_define_method(cPage, "get_text", page_get_text, 1); -+ rb_define_method(cPage, "get_text", page_get_text, -1); - rb_define_method(cPage, "link_mapping", page_get_link_mapping, 0); -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ rb_define_method(cPage, "image_mapping", page_get_image_mapping, 0); -+ rb_define_method(cPage, "form_field_mapping", -+ page_get_form_field_mapping, 0); -+#endif - rb_define_method(cPage, "get_selection_region", -- page_get_selection_region, 2); -+ page_get_selection_region, -1); - rb_define_method(cPage, "render_selection", - page_render_selection_generic, -1); -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+ rb_define_method(cPage, "crop_box", page_get_crop_box, 0); -+#endif - - G_DEF_SETTERS(cPage); - -@@ -335,5 +733,102 @@ Init_poppler_page(VALUE mPoppler) - rb_define_method(cLinkMapping, "area", link_mapping_get_area, 0); - rb_define_method(cLinkMapping, "action", link_mapping_get_action, 0); - -+ rb_define_method(cLinkMapping, "set_area", link_mapping_set_area, 1); -+ rb_define_method(cLinkMapping, "set_action", link_mapping_set_action, 1); -+ - G_DEF_SETTERS(cLinkMapping); -+ -+#if POPPLER_CHECK_VERSION(0, 6, 0) -+/* Page Transition */ -+ rb_define_method(cPageTransition, "type", page_trans_get_type, 0); -+ rb_define_method(cPageTransition, "alignment", page_trans_get_alignment, 0); -+ rb_define_method(cPageTransition, "direction", page_trans_get_direction, 0); -+ rb_define_method(cPageTransition, "duration", page_trans_get_duration, 0); -+ rb_define_method(cPageTransition, "angle", page_trans_get_angle, 0); -+ rb_define_method(cPageTransition, "scale", page_trans_get_scale, 0); -+ rb_define_method(cPageTransition, "rectangular", -+ page_trans_get_rectangular, 0); -+ -+ rb_define_method(cPageTransition, "set_type", page_trans_set_type, 1); -+ rb_define_method(cPageTransition, "set_alignment", -+ page_trans_set_alignment, 1); -+ rb_define_method(cPageTransition, "set_direction", -+ page_trans_set_direction, 1); -+ rb_define_method(cPageTransition, "set_duration", -+ page_trans_set_duration, 1); -+ rb_define_method(cPageTransition, "set_angle", page_trans_set_angle, 1); -+ rb_define_method(cPageTransition, "set_scale", page_trans_set_scale, 1); -+ rb_define_method(cPageTransition, "set_rectangular", -+ page_trans_set_rectangular, 1); -+ -+ G_DEF_SETTERS(cPageTransition); -+ -+ -+/* Mapping between areas on the current page and images */ -+ rb_define_method(cImageMapping, "area", image_mapping_get_area, 0); -+ rb_define_method(cImageMapping, "image", image_mapping_get_image, 0); -+ -+ rb_define_method(cImageMapping, "set_area", image_mapping_set_area, 1); -+ rb_define_method(cImageMapping, "set_image", image_mapping_set_image, 1); -+ -+ G_DEF_SETTERS(cImageMapping); -+ -+ -+/* Mapping between areas on the current page and form fields */ -+ rb_define_method(cFormFieldMapping, "area", form_field_mapping_get_area, 0); -+ rb_define_method(cFormFieldMapping, "field", form_field_mapping_get_field, -+ 0); -+ -+ rb_define_method(cFormFieldMapping, "set_area", -+ form_field_mapping_set_area, 1); -+ rb_define_method(cFormFieldMapping, "set_field", -+ form_field_mapping_set_field, 1); -+ -+ G_DEF_SETTERS(cFormFieldMapping); -+ -+/* FormField */ -+ rb_define_method(cFormField, "id", form_field_get_id, 0); -+ rb_define_method(cFormField, "font_size", form_field_get_font_size, 0); -+ rb_define_method(cFormField, "read_only?", form_field_is_read_only, 0); -+ -+ G_DEF_SETTERS(cFormField); -+ -+ -+ rb_define_method(cButtonField, "active?", button_field_get_state, 0); -+ rb_define_method(cButtonField, "set_active", button_field_set_state, 1); -+ -+ G_DEF_SETTERS(cButtonField); -+ -+ -+ rb_define_method(cTextField, "type", text_field_get_text_type, 0); -+ rb_define_method(cTextField, "text", text_field_get_text, 0); -+ rb_define_method(cTextField, "set_text", text_field_set_text, 1); -+ rb_define_method(cTextField, "max_length", text_field_get_max_length, 0); -+ rb_define_method(cTextField, "spell_check?", text_field_do_spell_check, 0); -+ rb_define_method(cTextField, "scroll?", text_field_do_scroll, 0); -+ rb_define_method(cTextField, "rich_text?", text_field_is_rich_text, 0); -+ rb_define_method(cTextField, "password?", text_field_is_password, 0); -+ -+ G_DEF_SETTERS(cTextField); -+ -+ -+ rb_define_method(cChoiceField, "type", choice_field_get_choice_type, 0); -+ rb_define_method(cChoiceField, "editable?", choice_field_is_editable, 0); -+ rb_define_method(cChoiceField, "select_multiple?", -+ choice_field_can_select_multiple, 0); -+ rb_define_method(cChoiceField, "spell_check?", -+ choice_field_do_spell_check, 0); -+ rb_define_method(cChoiceField, "commit_on_change?", -+ choice_field_commit_on_change, 0); -+ rb_define_method(cChoiceField, "n_items", choice_field_get_n_items, 0); -+ rb_define_method(cChoiceField, "[]", choice_field_get_item, 1); -+ rb_define_method(cChoiceField, "selected?", -+ choice_field_is_item_selected, 1); -+ rb_define_method(cChoiceField, "select", choice_field_select_item, 1); -+ rb_define_method(cChoiceField, "unselect_all", choice_field_unselect_all, 0); -+ rb_define_method(cChoiceField, "text", choice_field_get_text, 0); -+ rb_define_method(cChoiceField, "set_text", choice_field_set_text, 1); -+ -+ G_DEF_SETTERS(cChoiceField); -+#endif - } |