Add, save and open bookmarks

It is now possible to save bookmarks with a specific names for a
document, so you can jump easily to important sections of the pdf
later on.
This commit is contained in:
Moritz Lipp 2010-01-31 21:07:27 +01:00
parent 539331a084
commit db76477a18
2 changed files with 165 additions and 14 deletions

View file

@ -97,16 +97,18 @@ InputbarShortcut inputbar_shortcuts[] = {
/* commands */ /* commands */
Command commands[] = { Command commands[] = {
/* command, abbreviation, function, completion, description */ /* command, abbreviation, function, completion, description */
{"close", "c", cmd_close, 0, "Close current file" }, {"bmark", "b", cmd_bookmark, 0, "Bookmark current page" },
{"export", "e", cmd_export, cc_export, "Export images or attached files" }, {"blist", 0, cmd_open_bookmark, cc_bookmark, "List and open bookmark" },
{"info", "i", cmd_info, 0, "Show information about the document" }, {"close", "c", cmd_close, 0, "Close current file" },
{"open", "o", cmd_open, cc_open, "Open a file" }, {"export", "e", cmd_export, cc_export, "Export images or attached files" },
{"print", "p", cmd_print, cc_print, "Print the document" }, {"info", "i", cmd_info, 0, "Show information about the document" },
{"rotate", "r", cmd_rotate, 0, "Rotate the page" }, {"open", "o", cmd_open, cc_open, "Open a file" },
{"set", "s", cmd_set, cc_set, "Set an option" }, {"print", "p", cmd_print, cc_print, "Print the document" },
{"quit", "q", cmd_quit, 0, "Quit zjui" }, {"rotate", "r", cmd_rotate, 0, "Rotate the page" },
{"write", "w", cmd_save, 0, "Save the document" }, {"set", "s", cmd_set, cc_set, "Set an option" },
{"quit", "q", cmd_quit, 0, "Quit zjui" },
{"write", "w", cmd_save, 0, "Save the document" },
}; };
/* buffer commands */ /* buffer commands */

157
zathura.c
View file

@ -129,6 +129,12 @@ typedef struct
int page; int page;
} Marker; } Marker;
typedef struct
{
char* id;
int page;
} Bookmark;
/* zathura */ /* zathura */
struct struct
{ {
@ -213,6 +219,8 @@ struct
{ {
GKeyFile *data; GKeyFile *data;
char *file; char *file;
Bookmark *bookmarks;
int number_of_bookmarks;
} Bookmarks; } Bookmarks;
struct struct
@ -272,6 +280,8 @@ void isc_completion(Argument*);
void isc_string_manipulation(Argument*); void isc_string_manipulation(Argument*);
/* command declarations */ /* command declarations */
gboolean cmd_bookmark(int, char**);
gboolean cmd_open_bookmark(int, char**);
gboolean cmd_close(int, char**); gboolean cmd_close(int, char**);
gboolean cmd_export(int, char**); gboolean cmd_export(int, char**);
gboolean cmd_info(int, char**); gboolean cmd_info(int, char**);
@ -283,6 +293,7 @@ gboolean cmd_quit(int, char**);
gboolean cmd_save(int, char**); gboolean cmd_save(int, char**);
/* completion commands */ /* completion commands */
Completion* cc_bookmark(char*);
Completion* cc_export(char*); Completion* cc_export(char*);
Completion* cc_open(char*); Completion* cc_open(char*);
Completion* cc_print(char*); Completion* cc_print(char*);
@ -1427,8 +1438,8 @@ isc_completion(Argument* argument)
for(i = 0; i < LENGTH(commands); i++) for(i = 0; i < LENGTH(commands); i++)
{ {
int abbr_length = strlen(commands[i].abbr); int abbr_length = commands[i].abbr ? strlen(commands[i].abbr) : 0;
int cmd_length = strlen(commands[i].command); int cmd_length = commands[i].command ? strlen(commands[i].command) : 0;
/* add command to list iff /* add command to list iff
* the current command would match the command * the current command would match the command
@ -1536,6 +1547,77 @@ isc_string_manipulation(Argument* argument)
} }
/* command implementation */ /* command implementation */
gboolean
cmd_bookmark(int argc, char** argv)
{
if(!Zathura.PDF.document || argc < 1)
return TRUE;
/* get id */
int i;
GString *id = g_string_new("");
for(i = 0; i < argc; i++)
{
if(i != 0)
id = g_string_append_c(id, ' ');
id = g_string_append(id, argv[i]);
}
/* check for existing bookmark to overwrite */
for(i = 0; i < Zathura.Bookmarks.number_of_bookmarks; i++)
{
if(!strcmp(id->str, Zathura.Bookmarks.bookmarks[i].id))
{
Zathura.Bookmarks.bookmarks[i].page = Zathura.PDF.page_number;
return TRUE;
}
}
/* add new bookmark */
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
(Zathura.Bookmarks.number_of_bookmarks + 1) * sizeof(Bookmark));
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].id = id->str;
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page = Zathura.PDF.page_number;
Zathura.Bookmarks.number_of_bookmarks++;
return TRUE;
}
gboolean
cmd_open_bookmark(int argc, char** argv)
{
if(!Zathura.PDF.document || argc < 1)
return TRUE;
/* get id */
int i;
GString *id = g_string_new("");
for(i = 0; i < argc; i++)
{
if(i != 0)
id = g_string_append_c(id, ' ');
id = g_string_append(id, argv[i]);
}
/* find bookmark */
for(i = 0; i < Zathura.Bookmarks.number_of_bookmarks; i++)
{
if(!strcmp(id->str, Zathura.Bookmarks.bookmarks[i].id))
{
set_page(Zathura.Bookmarks.bookmarks[i].page);
return TRUE;
}
}
notify(WARNING, "No matching bookmark found");
return FALSE;
}
gboolean gboolean
cmd_close(int argc, char** argv) cmd_close(int argc, char** argv)
{ {
@ -1562,9 +1644,14 @@ cmd_close(int argc, char** argv)
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file, g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
BM_PAGE_ENTRY, Zathura.PDF.page_number); BM_PAGE_ENTRY, Zathura.PDF.page_number);
/* save bookmarks */
int i;
for(i = 0; i < Zathura.Bookmarks.number_of_bookmarks; i++)
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
Zathura.Bookmarks.bookmarks[i].id, Zathura.Bookmarks.bookmarks[i].page);
/* convert file and save it */ /* convert file and save it */
gchar* bookmarks = g_key_file_to_data(Zathura.Bookmarks.data, NULL, NULL); gchar* bookmarks = g_key_file_to_data(Zathura.Bookmarks.data, NULL, NULL);
printf("Saving to %s\n", Zathura.Bookmarks.file);
g_file_set_contents(Zathura.Bookmarks.file, bookmarks, -1, NULL); g_file_set_contents(Zathura.Bookmarks.file, bookmarks, -1, NULL);
g_free(bookmarks); g_free(bookmarks);
} }
@ -1835,16 +1922,39 @@ cmd_open(int argc, char** argv)
pthread_mutex_init(&(Zathura.PDF.pages[i]->lock), NULL); pthread_mutex_init(&(Zathura.PDF.pages[i]->lock), NULL);
} }
/* render pages */ /* start page */
int start_page = 0; int start_page = 0;
/* bookmarks */
if(Zathura.Bookmarks.data) if(Zathura.Bookmarks.data)
{ {
/* get last opened page */
if(g_key_file_has_group(Zathura.Bookmarks.data, file)) if(g_key_file_has_group(Zathura.Bookmarks.data, file))
if(g_key_file_has_key(Zathura.Bookmarks.data, file, BM_PAGE_ENTRY, NULL)) if(g_key_file_has_key(Zathura.Bookmarks.data, file, BM_PAGE_ENTRY, NULL))
start_page = g_key_file_get_integer(Zathura.Bookmarks.data, file, BM_PAGE_ENTRY, NULL); start_page = g_key_file_get_integer(Zathura.Bookmarks.data, file, BM_PAGE_ENTRY, NULL);
/* open and read bookmark file */
gsize i = 0;
gsize number_of_keys = 0;
char** keys = g_key_file_get_keys(Zathura.Bookmarks.data, file, &number_of_keys, NULL);
for(i = 0; i < number_of_keys; i++)
{
if(strcmp(keys[i], BM_PAGE_ENTRY))
{
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
(Zathura.Bookmarks.number_of_bookmarks + 1) * sizeof(Bookmark));
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].id = keys[i];
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page =
g_key_file_get_integer(Zathura.Bookmarks.data, file, keys[i], NULL);
Zathura.Bookmarks.number_of_bookmarks++;
}
}
} }
/* show document */
set_page(start_page); set_page(start_page);
update_status(); update_status();
@ -1958,6 +2068,45 @@ cmd_save(int argc, char** argv)
} }
/* completion command implementation */ /* completion command implementation */
Completion*
cc_bookmark(char* input)
{
/* init completion group */
Completion *completion = malloc(sizeof(Completion));
CompletionGroup* group = malloc(sizeof(CompletionGroup));
group->value = NULL;
group->next = NULL;
group->elements = NULL;
completion->groups = group;
CompletionElement *last_element = NULL;
int element_counter = 0;
int i = 0;
int input_length = input ? strlen(input) : 0;
for(i = 0; i < Zathura.Bookmarks.number_of_bookmarks; i++)
{
if( (input_length <= strlen(Zathura.Bookmarks.bookmarks[i].id)) &&
!strncmp(input, Zathura.Bookmarks.bookmarks[i].id, input_length) )
{
CompletionElement* el = malloc(sizeof(CompletionElement));
el->value = Zathura.Bookmarks.bookmarks[i].id;
el->description = g_strdup_printf("Page: %d", Zathura.Bookmarks.bookmarks[i].page);
el->next = NULL;
if(element_counter++ != 0)
last_element->next = el;
else
group->elements = el;
last_element = el;
}
}
return completion;
}
Completion* Completion*
cc_export(char* input) cc_export(char* input)
{ {