mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-01 09:06:07 +01:00
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:
parent
539331a084
commit
db76477a18
2 changed files with 165 additions and 14 deletions
22
config.def.h
22
config.def.h
|
@ -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
157
zathura.c
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue