mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-04 00:16:00 +01:00
Began to implement the index view
This commit is contained in:
parent
c41f945994
commit
31027cbaad
8 changed files with 127 additions and 23 deletions
|
@ -214,12 +214,6 @@ zathura_document_index_generate(zathura_document_t* document)
|
||||||
return document->functions.document_index_generate(document);
|
return document->functions.document_index_generate(document);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
|
||||||
zathura_document_index_free(zathura_list_t* list)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
zathura_list_t*
|
zathura_list_t*
|
||||||
zathura_document_attachments_get(zathura_document_t* document)
|
zathura_document_attachments_get(zathura_document_t* document)
|
||||||
{
|
{
|
||||||
|
|
|
@ -117,7 +117,6 @@ zathura_document_t* zathura_document_open(const char* path, const char* password
|
||||||
bool zathura_document_free(zathura_document_t* document);
|
bool zathura_document_free(zathura_document_t* document);
|
||||||
bool zathura_document_save_as(zathura_document_t* document, const char* path);
|
bool zathura_document_save_as(zathura_document_t* document, const char* path);
|
||||||
girara_tree_node_t* zathura_document_index_generate(zathura_document_t* document);
|
girara_tree_node_t* zathura_document_index_generate(zathura_document_t* document);
|
||||||
bool zathura_document_index_free(zathura_list_t* list);
|
|
||||||
zathura_list_t* zathura_document_attachments_get(zathura_document_t* document);
|
zathura_list_t* zathura_document_attachments_get(zathura_document_t* document);
|
||||||
bool zathura_document_attachments_free(zathura_list_t* list);
|
bool zathura_document_attachments_free(zathura_list_t* list);
|
||||||
|
|
||||||
|
|
16
ft/pdf/pdf.c
16
ft/pdf/pdf.c
|
@ -103,32 +103,32 @@ build_index(pdf_document_t* pdf, girara_tree_node_t* root, PopplerIndexIter* ite
|
||||||
}
|
}
|
||||||
|
|
||||||
gchar* markup = g_markup_escape_text(action->any.title, -1);
|
gchar* markup = g_markup_escape_text(action->any.title, -1);
|
||||||
zathura_index_element_t* indexelement = zathura_index_element_new(markup);
|
zathura_index_element_t* index_element = zathura_index_element_new(markup);
|
||||||
|
|
||||||
if (action->type == POPPLER_ACTION_URI) {
|
if (action->type == POPPLER_ACTION_URI) {
|
||||||
indexelement->type = ZATHURA_LINK_EXTERNAL;
|
index_element->type = ZATHURA_LINK_EXTERNAL;
|
||||||
indexelement->target.uri = g_strdup(action->uri.uri);
|
index_element->target.uri = g_strdup(action->uri.uri);
|
||||||
} else if (action->type == POPPLER_ACTION_GOTO_DEST) {
|
} else if (action->type == POPPLER_ACTION_GOTO_DEST) {
|
||||||
indexelement->type = ZATHURA_LINK_TO_PAGE;
|
index_element->type = ZATHURA_LINK_TO_PAGE;
|
||||||
|
|
||||||
if (action->goto_dest.dest->type == POPPLER_DEST_NAMED) {
|
if (action->goto_dest.dest->type == POPPLER_DEST_NAMED) {
|
||||||
PopplerDest* dest = poppler_document_find_dest(pdf->document, action->goto_dest.dest->named_dest);
|
PopplerDest* dest = poppler_document_find_dest(pdf->document, action->goto_dest.dest->named_dest);
|
||||||
if (dest) {
|
if (dest) {
|
||||||
indexelement->target.page_number = dest->page_num - 1;
|
index_element->target.page_number = dest->page_num - 1;
|
||||||
poppler_dest_free(dest);
|
poppler_dest_free(dest);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
indexelement->target.page_number = action->goto_dest.dest->page_num - 1;
|
index_element->target.page_number = action->goto_dest.dest->page_num - 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
poppler_action_free(action);
|
poppler_action_free(action);
|
||||||
zathura_index_element_free(indexelement);
|
zathura_index_element_free(index_element);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
poppler_action_free(action);
|
poppler_action_free(action);
|
||||||
|
|
||||||
girara_tree_node_t* node = girara_node_append_data(root, indexelement);
|
girara_tree_node_t* node = girara_node_append_data(root, index_element);
|
||||||
PopplerIndexIter* child = poppler_index_iter_get_child(iter);
|
PopplerIndexIter* child = poppler_index_iter_get_child(iter);
|
||||||
|
|
||||||
if (child) {
|
if (child) {
|
||||||
|
|
99
shortcuts.c
99
shortcuts.c
|
@ -7,6 +7,7 @@
|
||||||
#include "shortcuts.h"
|
#include "shortcuts.h"
|
||||||
#include "zathura.h"
|
#include "zathura.h"
|
||||||
#include "render.h"
|
#include "render.h"
|
||||||
|
#include "utils.h"
|
||||||
|
|
||||||
bool
|
bool
|
||||||
sc_abort(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
sc_abort(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
|
@ -67,7 +68,7 @@ sc_follow(girara_session_t* session, girara_argument_t* argument, unsigned int t
|
||||||
bool
|
bool
|
||||||
sc_goto(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
sc_goto(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
{
|
{
|
||||||
if (!session || !argument) {
|
if (session == NULL || argument == NULL || Zathura.document == NULL) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,7 +100,7 @@ sc_goto(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
bool
|
bool
|
||||||
sc_navigate(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
sc_navigate(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
{
|
{
|
||||||
if (!session || !argument || !Zathura.document) {
|
if (session == NULL || argument == NULL || Zathura.document == NULL) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,6 +203,88 @@ sc_navigate_index(girara_session_t* session, girara_argument_t* argument, unsign
|
||||||
bool
|
bool
|
||||||
sc_toggle_index(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
sc_toggle_index(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
{
|
{
|
||||||
|
if (session == NULL || Zathura.document == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
girara_tree_node_t* document_index = NULL;
|
||||||
|
GtkWidget* treeview = NULL;
|
||||||
|
GtkTreeModel* model = NULL;
|
||||||
|
GtkCellRenderer* renderer = NULL;
|
||||||
|
|
||||||
|
if (Zathura.UI.index == NULL) {
|
||||||
|
/* create new index widget */
|
||||||
|
Zathura.UI.index = gtk_scrolled_window_new(NULL, NULL);
|
||||||
|
|
||||||
|
if (Zathura.UI.index == NULL) {
|
||||||
|
goto error_ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(Zathura.UI.index),
|
||||||
|
GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
|
||||||
|
|
||||||
|
/* create index */
|
||||||
|
document_index = zathura_document_index_generate(Zathura.document);
|
||||||
|
if (document_index == NULL) {
|
||||||
|
// TODO: Error message
|
||||||
|
goto error_free;
|
||||||
|
}
|
||||||
|
|
||||||
|
model = GTK_TREE_MODEL(gtk_tree_store_new(2, G_TYPE_STRING, G_TYPE_POINTER));
|
||||||
|
if (model == NULL) {
|
||||||
|
goto error_free;
|
||||||
|
}
|
||||||
|
|
||||||
|
treeview = gtk_tree_view_new_with_model(model);
|
||||||
|
if (treeview == NULL) {
|
||||||
|
goto error_free;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_object_unref(model);
|
||||||
|
|
||||||
|
renderer = gtk_cell_renderer_text_new();
|
||||||
|
if (renderer == NULL) {
|
||||||
|
goto error_free;
|
||||||
|
}
|
||||||
|
|
||||||
|
document_index_build(model, NULL, document_index);
|
||||||
|
girara_node_free(document_index);
|
||||||
|
|
||||||
|
/* setup widget */
|
||||||
|
gtk_tree_view_insert_column_with_attributes(GTK_TREE_VIEW (treeview), 0, "Title", renderer, "markup", 0, NULL);
|
||||||
|
gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(treeview), FALSE);
|
||||||
|
g_object_set(G_OBJECT(renderer), "ellipsize", PANGO_ELLIPSIZE_END, NULL);
|
||||||
|
g_object_set(G_OBJECT(gtk_tree_view_get_column(GTK_TREE_VIEW(treeview), 0)), "expand", TRUE, NULL);
|
||||||
|
gtk_tree_view_set_cursor(GTK_TREE_VIEW(treeview), gtk_tree_path_new_first(), NULL, FALSE);
|
||||||
|
/*g_signal_connect(G_OBJECT(treeview), "row-activated", G_CALLBACK(cb_index_row_activated), NULL); TODO*/
|
||||||
|
|
||||||
|
gtk_container_add(GTK_CONTAINER(Zathura.UI.index), treeview);
|
||||||
|
gtk_widget_show(treeview);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (GTK_WIDGET_VISIBLE(GTK_WIDGET(Zathura.UI.index))) {
|
||||||
|
girara_set_view(session, Zathura.UI.page_view);
|
||||||
|
gtk_widget_hide(GTK_WIDGET(Zathura.UI.index));
|
||||||
|
} else {
|
||||||
|
girara_set_view(session, Zathura.UI.index);
|
||||||
|
gtk_widget_show(GTK_WIDGET(Zathura.UI.index));
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
|
||||||
|
error_free:
|
||||||
|
|
||||||
|
if (Zathura.UI.index != NULL) {
|
||||||
|
g_object_unref(Zathura.UI.index);
|
||||||
|
Zathura.UI.index = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (document_index != NULL) {
|
||||||
|
girara_node_free(document_index);
|
||||||
|
}
|
||||||
|
|
||||||
|
error_ret:
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,10 +295,11 @@ sc_toggle_inputbar(girara_session_t* session, girara_argument_t* argument, unsig
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(GTK_WIDGET_VISIBLE(GTK_WIDGET(session->gtk.inputbar)))
|
if (GTK_WIDGET_VISIBLE(GTK_WIDGET(session->gtk.inputbar))) {
|
||||||
gtk_widget_hide(GTK_WIDGET(session->gtk.inputbar));
|
gtk_widget_hide(GTK_WIDGET(session->gtk.inputbar));
|
||||||
else
|
} else {
|
||||||
gtk_widget_show(GTK_WIDGET(session->gtk.inputbar));
|
gtk_widget_show(GTK_WIDGET(session->gtk.inputbar));
|
||||||
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -247,10 +331,11 @@ sc_toggle_statusbar(girara_session_t* session, girara_argument_t* argument, unsi
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(GTK_WIDGET_VISIBLE(GTK_WIDGET(session->gtk.statusbar)))
|
if (GTK_WIDGET_VISIBLE(GTK_WIDGET(session->gtk.statusbar))) {
|
||||||
gtk_widget_hide(GTK_WIDGET(session->gtk.statusbar));
|
gtk_widget_hide(GTK_WIDGET(session->gtk.statusbar));
|
||||||
else
|
} else {
|
||||||
gtk_widget_show(GTK_WIDGET(session->gtk.statusbar));
|
gtk_widget_show(GTK_WIDGET(session->gtk.statusbar));
|
||||||
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -271,7 +356,7 @@ sc_quit(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
bool
|
bool
|
||||||
sc_zoom(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
sc_zoom(girara_session_t* session, girara_argument_t* argument, unsigned int t)
|
||||||
{
|
{
|
||||||
if (session == NULL || argument == NULL) {
|
if (session == NULL || argument == NULL || Zathura.document == NULL) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
15
utils.c
15
utils.c
|
@ -8,6 +8,7 @@
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
|
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
|
#include "zathura.h"
|
||||||
|
|
||||||
#define BLOCK_SIZE 64
|
#define BLOCK_SIZE 64
|
||||||
|
|
||||||
|
@ -157,8 +158,20 @@ page_blank(unsigned int width, unsigned int height)
|
||||||
gtk_image_set_from_pixbuf(GTK_IMAGE(image), pixbuf);
|
gtk_image_set_from_pixbuf(GTK_IMAGE(image), pixbuf);
|
||||||
gtk_widget_show(image);
|
gtk_widget_show(image);
|
||||||
|
|
||||||
/*free(buffer);*/
|
/*free(buffer);*/ // XXX: Read documentation
|
||||||
g_object_unref(pixbuf);
|
g_object_unref(pixbuf);
|
||||||
|
|
||||||
return image;
|
return image;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
document_index_build(GtkTreeModel* model, GtkTreeIter* parent, girara_tree_node_t* tree)
|
||||||
|
{
|
||||||
|
girara_list_t* list = girara_node_get_children(tree);
|
||||||
|
girara_list_iterator_t* it = girara_list_iterator(list);
|
||||||
|
|
||||||
|
do {
|
||||||
|
zathura_index_element_t* index_element = (zathura_index_element_t*) girara_list_iterator_data(it);
|
||||||
|
printf("%s\n", index_element->title);
|
||||||
|
} while ((it = girara_list_iterator_next(it)));
|
||||||
|
}
|
||||||
|
|
11
utils.h
11
utils.h
|
@ -5,6 +5,7 @@
|
||||||
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
#include <girara.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if the given file exists
|
* Checks if the given file exists
|
||||||
|
@ -40,4 +41,14 @@ bool execute_command(char* const argv[], char** output);
|
||||||
*/
|
*/
|
||||||
GtkWidget* page_blank(unsigned int width, unsigned int height);
|
GtkWidget* page_blank(unsigned int width, unsigned int height);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates the document index based upon the list retreived from the document
|
||||||
|
* object.
|
||||||
|
*
|
||||||
|
* @param model The tree model
|
||||||
|
* @param tree_it The Tree iterator
|
||||||
|
* @param list_it The index list iterator
|
||||||
|
*/
|
||||||
|
void document_index_build(GtkTreeModel* model, GtkTreeIter* parent, girara_tree_node_t* tree);
|
||||||
|
|
||||||
#endif // UTILS_H
|
#endif // UTILS_H
|
||||||
|
|
|
@ -26,6 +26,7 @@ init_zathura()
|
||||||
Zathura.UI.statusbar.buffer = NULL;
|
Zathura.UI.statusbar.buffer = NULL;
|
||||||
Zathura.UI.statusbar.page_number = NULL;
|
Zathura.UI.statusbar.page_number = NULL;
|
||||||
Zathura.UI.page_view = NULL;
|
Zathura.UI.page_view = NULL;
|
||||||
|
Zathura.UI.index = NULL;
|
||||||
|
|
||||||
/* page view */
|
/* page view */
|
||||||
Zathura.UI.page_view = gtk_vbox_new(FALSE, 0);
|
Zathura.UI.page_view = gtk_vbox_new(FALSE, 0);
|
||||||
|
|
|
@ -38,6 +38,7 @@ struct
|
||||||
} statusbar;
|
} statusbar;
|
||||||
|
|
||||||
GtkWidget *page_view; /**> Widget that contains all rendered pages */
|
GtkWidget *page_view; /**> Widget that contains all rendered pages */
|
||||||
|
GtkWidget *index; /**> Widget to show the index of the document */
|
||||||
} UI;
|
} UI;
|
||||||
|
|
||||||
struct
|
struct
|
||||||
|
|
Loading…
Reference in a new issue