Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/backend/djvu/djvu-text.c
diff options
context:
space:
mode:
authorNickolay V. Shmyrev <nshmyrev@yandex.ru>2007-01-08 12:25:31 (GMT)
committer Nickolay V. Shmyrev <nshmyrev@src.gnome.org>2007-01-08 12:25:31 (GMT)
commit13a06349251874bd35d2f03c3fc93217cee749a2 (patch)
treea681279b008acb19f686ee265aaed2be0da8d9e8 /backend/djvu/djvu-text.c
parentafb550ab779e00918d8fe24742abee3a81ebfe93 (diff)
Reorganize source tree.
2007-01-08 Nickolay V. Shmyrev <nshmyrev@yandex.ru> * Makefile.am: * backend/Makefile.am: * backend/comics/Makefile.am: * backend/djvu/Makefile.am: * backend/dvi/Makefile.am: * backend/ev-async-renderer.c: * backend/ev-async-renderer.h: * backend/ev-attachment.c: * backend/ev-attachment.h: * backend/ev-backend-marshal.c: * backend/ev-document-factory.c: * backend/ev-document-factory.h: * backend/ev-document-find.c: * backend/ev-document-find.h: * backend/ev-document-fonts.c: * backend/ev-document-fonts.h: * backend/ev-document-images.c: * backend/ev-document-images.h: * backend/ev-document-info.h: * backend/ev-document-links.c: * backend/ev-document-links.h: * backend/ev-document-misc.c: * backend/ev-document-misc.h: * backend/ev-document-security.c: * backend/ev-document-security.h: * backend/ev-document-thumbnails.c: * backend/ev-document-thumbnails.h: * backend/ev-document-transition.c: * backend/ev-document-transition.h: * backend/ev-document.c: * backend/ev-document.h: * backend/ev-file-exporter.c: * backend/ev-file-exporter.h: * backend/ev-image.c: * backend/ev-image.h: * backend/ev-link-action.c: * backend/ev-link-action.h: * backend/ev-link-dest.c: * backend/ev-link-dest.h: * backend/ev-link.c: * backend/ev-link.h: * backend/ev-render-context.c: * backend/ev-render-context.h: * backend/ev-selection.c: * backend/ev-selection.h: * backend/impress/Makefile.am: * backend/pdf/Makefile.am: * backend/pixbuf/Makefile.am: * backend/ps/Makefile.am: * backend/ps/ps-document.c: (push_pixbuf), (interpreter_failed), (ps_document_widget_event), (setup_pixmap), (setup_page), (input), (start_interpreter), (stop_interpreter), (document_load), (ps_document_next_page), (render_page): * backend/tiff/Makefile.am: * comics/Makefile.am: * comics/comics-document.c: * comics/comics-document.h: * configure.ac: * cut-n-paste/zoom-control/ephy-zoom-control.c: * djvu/Makefile.am: * djvu/djvu-document-private.h: * djvu/djvu-document.c: * djvu/djvu-document.h: * djvu/djvu-links.c: * djvu/djvu-links.h: * djvu/djvu-text-page.c: * djvu/djvu-text-page.h: * djvu/djvu-text.c: * djvu/djvu-text.h: * dvi/Makefile.am: * dvi/dvi-document.c: * dvi/dvi-document.h: * dvi/fonts.c: * dvi/fonts.h: * dvi/mdvi-lib/Makefile.am: * dvi/mdvi-lib/afmparse.c: * dvi/mdvi-lib/afmparse.h: * dvi/mdvi-lib/bitmap.c: * dvi/mdvi-lib/bitmap.h: * dvi/mdvi-lib/color.c: * dvi/mdvi-lib/color.h: * dvi/mdvi-lib/common.c: * dvi/mdvi-lib/common.h: * dvi/mdvi-lib/defaults.h: * dvi/mdvi-lib/dvimisc.c: * dvi/mdvi-lib/dviopcodes.h: * dvi/mdvi-lib/dviread.c: * dvi/mdvi-lib/files.c: * dvi/mdvi-lib/font.c: * dvi/mdvi-lib/fontmap.c: * dvi/mdvi-lib/fontmap.h: * dvi/mdvi-lib/fontsrch.c: * dvi/mdvi-lib/gf.c: * dvi/mdvi-lib/hash.c: * dvi/mdvi-lib/hash.h: * dvi/mdvi-lib/list.c: * dvi/mdvi-lib/mdvi.h: * dvi/mdvi-lib/pagesel.c: * dvi/mdvi-lib/paper.c: * dvi/mdvi-lib/paper.h: * dvi/mdvi-lib/pk.c: * dvi/mdvi-lib/private.h: * dvi/mdvi-lib/setup.c: * dvi/mdvi-lib/sp-epsf.c: * dvi/mdvi-lib/special.c: * dvi/mdvi-lib/sysdeps.h: * dvi/mdvi-lib/t1.c: * dvi/mdvi-lib/tfm.c: * dvi/mdvi-lib/tfmfile.c: * dvi/mdvi-lib/tt.c: * dvi/mdvi-lib/util.c: * dvi/mdvi-lib/vf.c: * dvi/pixbuf-device.c: * dvi/pixbuf-device.h: * impress/Makefile.am: * impress/common.h: * impress/document.c: * impress/f_oasis.c: * impress/f_oo13.c: * impress/iksemel.c: * impress/iksemel.h: * impress/imposter.h: * impress/impress-document.c: * impress/impress-document.h: * impress/internal.h: * impress/r_back.c: * impress/r_draw.c: * impress/r_geometry.c: * impress/r_gradient.c: * impress/r_style.c: * impress/r_text.c: * impress/render.c: * impress/render.h: * impress/zip.c: * impress/zip.h: * lib/Makefile.am: * lib/ev-debug.c: * lib/ev-debug.h: * lib/ev-file-helpers.c: * lib/ev-file-helpers.h: * lib/ev-gui.c: * lib/ev-gui.h: * lib/ev-tooltip.c: * lib/ev-tooltip.h: * libdocument/Makefile.am: * libdocument/ev-file-helpers.c: * pdf/Makefile.am: * pdf/ev-poppler.cc: * pdf/ev-poppler.h: * pixbuf/Makefile.am: * pixbuf/pixbuf-document.c: * pixbuf/pixbuf-document.h: * properties/Makefile.am: * ps/Makefile.am: * ps/gsdefaults.c: * ps/gsdefaults.h: * ps/gsio.c: * ps/gsio.h: * ps/gstypes.h: * ps/ps-document.c: * ps/ps-document.h: * ps/ps.c: * ps/ps.h: * shell/Makefile.am: * shell/ev-application.h: * shell/ev-sidebar-links.c: * shell/ev-sidebar-links.h: * shell/ev-utils.c: (ev_gui_sanitise_popup_position), (ev_gui_menu_position_tree_selection): * shell/ev-utils.h: * shell/ev-view.c: (ev_view_finalize): * shell/ev-window.c: * shell/main.c: (main): * thumbnailer/Makefile.am: * tiff/Makefile.am: * tiff/tiff-document.c: * tiff/tiff-document.h: * tiff/tiff2ps.c: * tiff/tiff2ps.h: Reorganize source tree. svn path=/trunk/; revision=2197
Diffstat (limited to 'backend/djvu/djvu-text.c')
-rw-r--r--backend/djvu/djvu-text.c298
1 files changed, 298 insertions, 0 deletions
diff --git a/backend/djvu/djvu-text.c b/backend/djvu/djvu-text.c
new file mode 100644
index 0000000..beaac6b
--- /dev/null
+++ b/backend/djvu/djvu-text.c
@@ -0,0 +1,298 @@
+/*
+ * Implements search and copy functionality for Djvu files.
+ * Copyright (C) 2006 Michael Hofmann <mh21@piware.de>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#include "djvu-document-private.h"
+#include "djvu-document.h"
+#include "djvu-text.h"
+#include "djvu-text-page.h"
+#include "ev-document-find.h"
+#include "ev-document.h"
+
+#include <string.h>
+#include <glib.h>
+
+struct _DjvuText {
+ DjvuDocument *document;
+ gboolean case_sensitive;
+ char *text;
+ GList **pages;
+ guint idle;
+ int start_page;
+ int search_page;
+};
+
+/**
+ * djvu_text_idle_callback:
+ * @data: #DjvuText instance
+ *
+ * Idle callback that processes one page at a time.
+ *
+ * Returns: whether there are more pages to be processed
+ */
+static gboolean
+djvu_text_idle_callback (void *data)
+{
+ DjvuText *djvu_text = (DjvuText *) data;
+ DjvuDocument *djvu_document = djvu_text->document;
+ int n_pages;
+ miniexp_t page_text;
+
+ ev_document_doc_mutex_lock ();
+ while ((page_text =
+ ddjvu_document_get_pagetext (djvu_document->d_document,
+ djvu_text->search_page,
+ "char")) == miniexp_dummy)
+ djvu_handle_events (djvu_document, TRUE);
+
+ if (page_text != miniexp_nil) {
+ DjvuTextPage *page = djvu_text_page_new (page_text);
+ djvu_text_page_prepare_search (page, djvu_text->case_sensitive);
+ if (page->links->len > 0) {
+ djvu_text_page_search (page, djvu_text->text);
+ djvu_text->pages[djvu_text->search_page] = page->results;
+ ev_document_find_changed (EV_DOCUMENT_FIND
+ (djvu_document),
+ djvu_text->search_page);
+ }
+ djvu_text_page_free (page);
+ ddjvu_miniexp_release (djvu_document->d_document,
+ page_text);
+ }
+ ev_document_doc_mutex_unlock ();
+
+ n_pages =
+ djvu_document_get_n_pages (EV_DOCUMENT (djvu_text->document));
+ djvu_text->search_page += 1;
+ if (djvu_text->search_page == n_pages) {
+ /* wrap around */
+ djvu_text->search_page = 0;
+ }
+
+ if (djvu_text->search_page != djvu_text->start_page)
+ return TRUE;
+
+ /* We're done. */
+ djvu_text->idle = 0;
+ /* will return FALSE to remove */
+ return FALSE;
+}
+
+/**
+ * djvu_text_new:
+ * @djvu_document: document to search
+ * @start_page: first page to search
+ * @case_sensitive: uses g_utf8_case_fold() to enable case-insensitive
+ * searching
+ * @text: text to search
+ *
+ * Creates a new #DjvuText instance to enable searching. An idle call
+ * is used to process all pages starting from @start_page.
+ *
+ * Returns: newly created instance
+ */
+DjvuText *
+djvu_text_new (DjvuDocument *djvu_document,
+ int start_page,
+ gboolean case_sensitive,
+ const char *text)
+{
+ DjvuText *djvu_text;
+ int n_pages;
+ int i;
+
+ n_pages = djvu_document_get_n_pages (EV_DOCUMENT (djvu_document));
+
+ djvu_text = g_new0 (DjvuText, 1);
+
+ if (case_sensitive)
+ djvu_text->text = g_strdup (text);
+ else
+ djvu_text->text = g_utf8_casefold (text, -1);
+ djvu_text->pages = g_new0 (GList *, n_pages);
+ for (i = 0; i < n_pages; i++) {
+ djvu_text->pages[i] = NULL;
+ }
+
+ djvu_text->document = djvu_document;
+
+ /* We add at low priority so the progress bar repaints */
+ djvu_text->idle = g_idle_add_full (G_PRIORITY_LOW,
+ djvu_text_idle_callback,
+ djvu_text, NULL);
+
+ djvu_text->case_sensitive = case_sensitive;
+ djvu_text->start_page = start_page;
+ djvu_text->search_page = start_page;
+
+ return djvu_text;
+}
+
+/**
+ * djvu_text_copy:
+ * @djvu_document: document to search
+ * @page: page to search
+ * @rectangle: rectangle to copy
+ *
+ * Copies and returns the text in the given rectangle.
+ *
+ * Returns: newly allocated text or NULL of none is available
+ */
+char *
+djvu_text_copy (DjvuDocument *djvu_document,
+ int page,
+ EvRectangle *rectangle)
+{
+ miniexp_t page_text;
+ char* text = NULL;
+
+ while ((page_text =
+ ddjvu_document_get_pagetext (djvu_document->d_document,
+ page, "char")) == miniexp_dummy)
+ djvu_handle_events (djvu_document, TRUE);
+
+ if (page_text != miniexp_nil) {
+ DjvuTextPage *page = djvu_text_page_new (page_text);
+ text = djvu_text_page_copy (page, rectangle);
+ djvu_text_page_free (page);
+ ddjvu_miniexp_release (djvu_document->d_document, page_text);
+ }
+
+ return text;
+}
+
+/**
+ * djvu_text_free:
+ * @djvu_text: instance to free
+ *
+ * Frees the given #DjvuText instance.
+ */
+void djvu_text_free (DjvuText * djvu_text)
+{
+ DjvuDocument *djvu_document = djvu_text->document;
+ int n_pages;
+ int i;
+
+ if (djvu_text->idle != 0)
+ g_source_remove (djvu_text->idle);
+
+ n_pages = djvu_document_get_n_pages (EV_DOCUMENT (djvu_document));
+ for (i = 0; i < n_pages; i++) {
+ g_list_foreach (djvu_text->pages[i], (GFunc) g_free, NULL);
+ g_list_free (djvu_text->pages[i]);
+ }
+
+ g_free (djvu_text->text);
+}
+
+/**
+ * djvu_text_get_text:
+ * @djvu_text: #DjvuText instance
+ *
+ * Returns the search text. This is mainly to be able to avoid reinstantiation
+ * for the same search text.
+ *
+ * Returns: the text this instance of #DjvuText is looking for
+ */
+const char *
+djvu_text_get_text (DjvuText *djvu_text)
+{
+ return djvu_text->text;
+}
+
+/**
+ * djvu_text_n_results:
+ * @djvu_text: #DjvuText instance
+ * @page: page number
+ *
+ * Returns the number of search results available for the given page.
+ *
+ * Returns: number of search results
+ */
+int
+djvu_text_n_results (DjvuText *djvu_text,
+ int page)
+{
+ return g_list_length (djvu_text->pages[page]);
+}
+
+/**
+ * djvu_text_has_results:
+ * @djvu_text: #DjvuText instance
+ * @page: page number
+ *
+ * Returns whether there are search results available for the given page.
+ * This method executes faster than djvu_text_n_results().
+ *
+ * Returns: whether there are search results
+ */
+int
+djvu_text_has_results (DjvuText *djvu_text,
+ int page)
+{
+ return djvu_text->pages[page] != NULL;
+}
+
+/**
+ * djvu_text_get_result:
+ * @djvu_text: #DjvuText instance
+ * @page: page number
+ * @n_result: result number
+ *
+ * Returns the n-th search result of a given page. The coordinates are
+ * Djvu-specific and need to be processed to be compatible with the Evince
+ * coordinate system. The result may span several lines!
+ *
+ * Returns: the rectangle for the search result
+ */
+EvRectangle *
+djvu_text_get_result (DjvuText *djvu_text,
+ int page,
+ int n_result)
+{
+ return (EvRectangle *) g_list_nth_data (djvu_text->pages[page],
+ n_result);
+}
+
+/**
+ * djvu_text_get_progress:
+ * @djvu_text: #DjvuText instance
+ *
+ * Returns the percentage of pages done searching.
+ *
+ * Returns: the progress as value between 0 and 1
+ */
+double
+djvu_text_get_progress (DjvuText *djvu_text)
+{
+ int pages_done;
+ int n_pages;
+
+ n_pages =
+ djvu_document_get_n_pages (EV_DOCUMENT (djvu_text->document));
+ if (djvu_text->search_page > djvu_text->start_page) {
+ pages_done = djvu_text->search_page - djvu_text->start_page + 1;
+ } else if (djvu_text->search_page == djvu_text->start_page) {
+ pages_done = n_pages;
+ } else {
+ pages_done =
+ n_pages - djvu_text->start_page + djvu_text->search_page;
+ }
+ return pages_done / (double) n_pages;
+}
+