X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=libdocument%2Fev-document-links.c;h=b8aae5d71a5ac424671c6336e4b5567276350e89;hb=f4dd355fb0ec24f49be5d8d4321ceeeb9088fd90;hp=d74804b020c69f2751bb901199ce7487e6fb8cfd;hpb=ab26fbf217460c766111850bf40725e5e65a5533;p=evince.git diff --git a/libdocument/ev-document-links.c b/libdocument/ev-document-links.c index d74804b0..b8aae5d7 100644 --- a/libdocument/ev-document-links.c +++ b/libdocument/ev-document-links.c @@ -18,24 +18,24 @@ * * 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. + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "config.h" #include "ev-document-links.h" -EV_DEFINE_INTERFACE (EvDocumentLinks, ev_document_links, 0) +G_DEFINE_INTERFACE (EvDocumentLinks, ev_document_links, 0) static void -ev_document_links_class_init (EvDocumentLinksIface *klass) +ev_document_links_default_init (EvDocumentLinksInterface *klass) { } gboolean ev_document_links_has_document_links (EvDocumentLinks *document_links) { - EvDocumentLinksIface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); + EvDocumentLinksInterface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); gboolean retval; retval = iface->has_document_links (document_links); @@ -46,7 +46,7 @@ ev_document_links_has_document_links (EvDocumentLinks *document_links) GtkTreeModel * ev_document_links_get_links_model (EvDocumentLinks *document_links) { - EvDocumentLinksIface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); + EvDocumentLinksInterface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); GtkTreeModel *retval; retval = iface->get_links_model (document_links); @@ -54,23 +54,20 @@ ev_document_links_get_links_model (EvDocumentLinks *document_links) return retval; } -GList * +EvMappingList * ev_document_links_get_links (EvDocumentLinks *document_links, - gint page) + EvPage *page) { - EvDocumentLinksIface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); - GList *retval; + EvDocumentLinksInterface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); - retval = iface->get_links (document_links, page); - - return retval; + return iface->get_links (document_links, page); } EvLinkDest * ev_document_links_find_link_dest (EvDocumentLinks *document_links, const gchar *link_name) { - EvDocumentLinksIface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); + EvDocumentLinksInterface *iface = EV_DOCUMENT_LINKS_GET_IFACE (document_links); EvLinkDest *retval; ev_document_doc_mutex_lock (); @@ -79,3 +76,54 @@ ev_document_links_find_link_dest (EvDocumentLinks *document_links, return retval; } + +/* Helper functions */ +gint +ev_document_links_get_dest_page (EvDocumentLinks *document_links, + EvLinkDest *dest) +{ + gint page = -1; + + switch (ev_link_dest_get_dest_type (dest)) { + case EV_LINK_DEST_TYPE_NAMED: { + EvLinkDest *dest2; + + dest2 = ev_document_links_find_link_dest (document_links, + ev_link_dest_get_named_dest (dest)); + if (dest2) { + page = ev_link_dest_get_page (dest2); + g_object_unref (dest2); + } + } + break; + case EV_LINK_DEST_TYPE_PAGE_LABEL: + ev_document_find_page_by_label (EV_DOCUMENT (document_links), + ev_link_dest_get_page_label (dest), + &page); + break; + default: + page = ev_link_dest_get_page (dest); + } + + return page; +} + +gchar * +ev_document_links_get_dest_page_label (EvDocumentLinks *document_links, + EvLinkDest *dest) +{ + gchar *label = NULL; + + if (ev_link_dest_get_dest_type (dest) == EV_LINK_DEST_TYPE_PAGE_LABEL) { + label = g_strdup (ev_link_dest_get_page_label (dest)); + } else { + gint page; + + page = ev_document_links_get_dest_page (document_links, dest); + if (page != -1) + label = ev_document_get_page_label (EV_DOCUMENT (document_links), + page); + } + + return label; +}