mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-01 11:06:00 +01:00
Merge branch 'master' of pwmt.org:zathura
This commit is contained in:
commit
125af22b3a
3 changed files with 67 additions and 34 deletions
|
@ -16,7 +16,7 @@ static const char FORMAT_DESCRIPTION[] = "<i>%s</i>";
|
||||||
/* Use XDG directory specification if no config and data directory are given on
|
/* Use XDG directory specification if no config and data directory are given on
|
||||||
* the command line. Uncomment the next line if you just want to use CONFIG_DIR
|
* the command line. Uncomment the next line if you just want to use CONFIG_DIR
|
||||||
* and DATA_DIR instead (these will be the default locations if the XDG_*
|
* and DATA_DIR instead (these will be the default locations if the XDG_*
|
||||||
* environment variebles are not set anyway) */
|
* environment variables are not set anyway) */
|
||||||
/* #define ZATHURA_NO_XDG */
|
/* #define ZATHURA_NO_XDG */
|
||||||
|
|
||||||
/* directories and files */
|
/* directories and files */
|
||||||
|
@ -29,6 +29,7 @@ static const char DATA_DIR[] = "~/.local/share/zathura";
|
||||||
/* bookmarks */
|
/* bookmarks */
|
||||||
static const char BM_PAGE_ENTRY[] = "page";
|
static const char BM_PAGE_ENTRY[] = "page";
|
||||||
static const char BM_PAGE_OFFSET[] = "offset";
|
static const char BM_PAGE_OFFSET[] = "offset";
|
||||||
|
int save_position = 1;
|
||||||
|
|
||||||
/* look */
|
/* look */
|
||||||
char* font = "monospace normal 9";
|
char* font = "monospace normal 9";
|
||||||
|
@ -248,6 +249,7 @@ Setting settings[] = {
|
||||||
{"recolor", &(Zathura.Global.recolor), 'b', TRUE, FALSE, "Invert the image" },
|
{"recolor", &(Zathura.Global.recolor), 'b', TRUE, FALSE, "Invert the image" },
|
||||||
{"recolor_darkcolor", &(recolor_darkcolor), 's', FALSE, TRUE, "Recoloring (dark color)"},
|
{"recolor_darkcolor", &(recolor_darkcolor), 's', FALSE, TRUE, "Recoloring (dark color)"},
|
||||||
{"recolor_lightcolor", &(recolor_lightcolor), 's', FALSE, TRUE, "Recoloring (light color)"},
|
{"recolor_lightcolor", &(recolor_lightcolor), 's', FALSE, TRUE, "Recoloring (light color)"},
|
||||||
|
{"save_position", &(save_position), 'b', FALSE, FALSE, "Save position in file on quit and restore it on open"},
|
||||||
{"scroll_step", &(scroll_step), 'f', FALSE, FALSE, "Scroll step"},
|
{"scroll_step", &(scroll_step), 'f', FALSE, FALSE, "Scroll step"},
|
||||||
{"scroll_wrap", &(scroll_wrap), 'b', FALSE, FALSE, "Wrap scolling at last page"},
|
{"scroll_wrap", &(scroll_wrap), 'b', FALSE, FALSE, "Wrap scolling at last page"},
|
||||||
{"scrollbars", &(show_scrollbars), 'b', FALSE, TRUE, "Show scrollbars"},
|
{"scrollbars", &(show_scrollbars), 'b', FALSE, TRUE, "Show scrollbars"},
|
||||||
|
|
|
@ -15,7 +15,7 @@ INCS = -I. -I/usr/include ${GTK_INC}
|
||||||
LIBS = -lc ${GTK_LIB} -lpthread -lm
|
LIBS = -lc ${GTK_LIB} -lpthread -lm
|
||||||
|
|
||||||
# compiler flags
|
# compiler flags
|
||||||
CFLAGS += -std=c99 -pedantic -Wall -Wno-format-zero-length $(INCS)
|
CFLAGS += -std=c99 -pedantic -Wall $(INCS)
|
||||||
|
|
||||||
# debug flags
|
# debug flags
|
||||||
DFLAGS = -g
|
DFLAGS = -g
|
||||||
|
|
83
zathura.c
83
zathura.c
|
@ -371,6 +371,7 @@ gboolean open_stdin(gchar*);
|
||||||
void open_uri(char*);
|
void open_uri(char*);
|
||||||
void out_of_memory(void) NORETURN;
|
void out_of_memory(void) NORETURN;
|
||||||
void update_status(void);
|
void update_status(void);
|
||||||
|
void read_bookmarks_file(void);
|
||||||
void read_configuration_file(const char*);
|
void read_configuration_file(const char*);
|
||||||
void read_configuration(void);
|
void read_configuration(void);
|
||||||
void recalcRectangle(int, PopplerRectangle*);
|
void recalcRectangle(int, PopplerRectangle*);
|
||||||
|
@ -609,26 +610,12 @@ init_directories(void)
|
||||||
void
|
void
|
||||||
init_bookmarks(void)
|
init_bookmarks(void)
|
||||||
{
|
{
|
||||||
/* create or open existing bookmark file */
|
/* init variables */
|
||||||
Zathura.Bookmarks.data = g_key_file_new();
|
Zathura.Bookmarks.number_of_bookmarks = 0;
|
||||||
gchar* bookmarks = g_build_filename(Zathura.Config.data_dir, BOOKMARK_FILE, NULL);
|
Zathura.Bookmarks.bookmarks = NULL;
|
||||||
|
|
||||||
if(!g_file_test(bookmarks, G_FILE_TEST_IS_REGULAR))
|
Zathura.Bookmarks.file = g_build_filename(Zathura.Config.data_dir, BOOKMARK_FILE, NULL);
|
||||||
{
|
read_bookmarks_file();
|
||||||
/* file does not exist */
|
|
||||||
g_file_set_contents(bookmarks, "# Zathura bookmarks\n", -1, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
GError* error = NULL;
|
|
||||||
if(!g_key_file_load_from_file(Zathura.Bookmarks.data, bookmarks,
|
|
||||||
G_KEY_FILE_KEEP_COMMENTS | G_KEY_FILE_KEEP_TRANSLATIONS, &error))
|
|
||||||
{
|
|
||||||
gchar* message = g_strdup_printf("Could not load bookmark file: %s", error->message);
|
|
||||||
notify(ERROR, message);
|
|
||||||
g_free(message);
|
|
||||||
}
|
|
||||||
|
|
||||||
Zathura.Bookmarks.file = bookmarks;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -683,7 +670,7 @@ init_zathura(void)
|
||||||
Zathura.Global.show_inputbar = TRUE;
|
Zathura.Global.show_inputbar = TRUE;
|
||||||
Zathura.Global.show_statusbar = TRUE;
|
Zathura.Global.show_statusbar = TRUE;
|
||||||
|
|
||||||
Zathura.State.pages = g_strdup_printf("");
|
Zathura.State.pages = g_strdup("");
|
||||||
Zathura.State.scroll_percentage = 0;
|
Zathura.State.scroll_percentage = 0;
|
||||||
|
|
||||||
Zathura.Marker.markers = NULL;
|
Zathura.Marker.markers = NULL;
|
||||||
|
@ -1053,6 +1040,10 @@ close_file(gboolean keep_monitor)
|
||||||
|
|
||||||
/* save bookmarks */
|
/* save bookmarks */
|
||||||
if(Zathura.Bookmarks.data)
|
if(Zathura.Bookmarks.data)
|
||||||
|
{
|
||||||
|
read_bookmarks_file();
|
||||||
|
|
||||||
|
if(save_position)
|
||||||
{
|
{
|
||||||
/* set current page */
|
/* set current page */
|
||||||
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
|
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
|
||||||
|
@ -1061,12 +1052,18 @@ close_file(gboolean keep_monitor)
|
||||||
/* set page offset */
|
/* set page offset */
|
||||||
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
|
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
|
||||||
BM_PAGE_OFFSET, Zathura.PDF.page_offset);
|
BM_PAGE_OFFSET, Zathura.PDF.page_offset);
|
||||||
|
}
|
||||||
|
|
||||||
/* save bookmarks */
|
/* save bookmarks */
|
||||||
int i;
|
int i;
|
||||||
for(i = 0; i < Zathura.Bookmarks.number_of_bookmarks; i++)
|
for(i = 0; i < Zathura.Bookmarks.number_of_bookmarks; i++)
|
||||||
|
{
|
||||||
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
|
g_key_file_set_integer(Zathura.Bookmarks.data, Zathura.PDF.file,
|
||||||
Zathura.Bookmarks.bookmarks[i].id, Zathura.Bookmarks.bookmarks[i].page);
|
Zathura.Bookmarks.bookmarks[i].id, Zathura.Bookmarks.bookmarks[i].page);
|
||||||
|
g_free(Zathura.Bookmarks.bookmarks[i].id);
|
||||||
|
}
|
||||||
|
free(Zathura.Bookmarks.bookmarks);
|
||||||
|
Zathura.Bookmarks.number_of_bookmarks = 0;
|
||||||
|
|
||||||
/* 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);
|
||||||
|
@ -1093,7 +1090,7 @@ close_file(gboolean keep_monitor)
|
||||||
g_free(Zathura.State.pages);
|
g_free(Zathura.State.pages);
|
||||||
gtk_window_set_title(GTK_WINDOW(Zathura.UI.window), "zathura");
|
gtk_window_set_title(GTK_WINDOW(Zathura.UI.window), "zathura");
|
||||||
|
|
||||||
Zathura.State.pages = g_strdup_printf("");
|
Zathura.State.pages = g_strdup("");
|
||||||
g_free(Zathura.State.filename);
|
g_free(Zathura.State.filename);
|
||||||
Zathura.State.filename = g_strdup((char*) default_text);
|
Zathura.State.filename = g_strdup((char*) default_text);
|
||||||
|
|
||||||
|
@ -1371,11 +1368,11 @@ open_file(char* path, char* password)
|
||||||
if(Zathura.Bookmarks.data && g_key_file_has_group(Zathura.Bookmarks.data, file))
|
if(Zathura.Bookmarks.data && g_key_file_has_group(Zathura.Bookmarks.data, file))
|
||||||
{
|
{
|
||||||
/* get last opened page */
|
/* get last opened page */
|
||||||
if(g_key_file_has_key(Zathura.Bookmarks.data, file, BM_PAGE_ENTRY, NULL))
|
if(save_position && 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);
|
||||||
|
|
||||||
/* get page offset */
|
/* get page offset */
|
||||||
if(g_key_file_has_key(Zathura.Bookmarks.data, file, BM_PAGE_OFFSET, NULL))
|
if(save_position && g_key_file_has_key(Zathura.Bookmarks.data, file, BM_PAGE_OFFSET, NULL))
|
||||||
Zathura.PDF.page_offset = g_key_file_get_integer(Zathura.Bookmarks.data, file, BM_PAGE_OFFSET, NULL);
|
Zathura.PDF.page_offset = g_key_file_get_integer(Zathura.Bookmarks.data, file, BM_PAGE_OFFSET, NULL);
|
||||||
if((Zathura.PDF.page_offset != 0) && (Zathura.PDF.page_offset != GOTO_OFFSET))
|
if((Zathura.PDF.page_offset != 0) && (Zathura.PDF.page_offset != GOTO_OFFSET))
|
||||||
Zathura.PDF.page_offset = GOTO_OFFSET;
|
Zathura.PDF.page_offset = GOTO_OFFSET;
|
||||||
|
@ -1392,7 +1389,7 @@ open_file(char* path, char* password)
|
||||||
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
||||||
(Zathura.Bookmarks.number_of_bookmarks + 1) * sizeof(Bookmark));
|
(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].id = g_strdup(keys[i]);
|
||||||
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page =
|
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page =
|
||||||
g_key_file_get_integer(Zathura.Bookmarks.data, file, keys[i], NULL);
|
g_key_file_get_integer(Zathura.Bookmarks.data, file, keys[i], NULL);
|
||||||
|
|
||||||
|
@ -1520,6 +1517,31 @@ update_status(void)
|
||||||
g_free(zoom_level);
|
g_free(zoom_level);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
read_bookmarks_file(void)
|
||||||
|
{
|
||||||
|
/* free it at first */
|
||||||
|
if (Zathura.Bookmarks.data)
|
||||||
|
g_key_file_free(Zathura.Bookmarks.data);
|
||||||
|
|
||||||
|
/* create or open existing bookmark file */
|
||||||
|
Zathura.Bookmarks.data = g_key_file_new();
|
||||||
|
if(!g_file_test(Zathura.Bookmarks.file, G_FILE_TEST_IS_REGULAR))
|
||||||
|
{
|
||||||
|
/* file does not exist */
|
||||||
|
g_file_set_contents(Zathura.Bookmarks.file, "# Zathura bookmarks\n", -1, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
GError* error = NULL;
|
||||||
|
if(!g_key_file_load_from_file(Zathura.Bookmarks.data, Zathura.Bookmarks.file,
|
||||||
|
G_KEY_FILE_KEEP_COMMENTS | G_KEY_FILE_KEEP_TRANSLATIONS, &error))
|
||||||
|
{
|
||||||
|
gchar* message = g_strdup_printf("Could not load bookmark file: %s", error->message);
|
||||||
|
notify(ERROR, message);
|
||||||
|
g_free(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
read_configuration_file(const char* rcfile)
|
read_configuration_file(const char* rcfile)
|
||||||
{
|
{
|
||||||
|
@ -2966,7 +2988,7 @@ cmd_bookmark(int argc, char** argv)
|
||||||
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
Zathura.Bookmarks.bookmarks = realloc(Zathura.Bookmarks.bookmarks,
|
||||||
(Zathura.Bookmarks.number_of_bookmarks + 1) * sizeof(Bookmark));
|
(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].id = g_strdup(id->str);
|
||||||
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page = Zathura.PDF.page_number;
|
Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks].page = Zathura.PDF.page_number;
|
||||||
Zathura.Bookmarks.number_of_bookmarks++;
|
Zathura.Bookmarks.number_of_bookmarks++;
|
||||||
|
|
||||||
|
@ -3057,6 +3079,7 @@ cmd_delete_bookmark(int argc, char** argv)
|
||||||
/* update key file */
|
/* update key file */
|
||||||
g_key_file_remove_key(Zathura.Bookmarks.data, Zathura.PDF.file, Zathura.Bookmarks.bookmarks[i].id, NULL);
|
g_key_file_remove_key(Zathura.Bookmarks.data, Zathura.PDF.file, Zathura.Bookmarks.bookmarks[i].id, NULL);
|
||||||
|
|
||||||
|
g_free(Zathura.Bookmarks.bookmarks[i].id);
|
||||||
/* update bookmarks */
|
/* update bookmarks */
|
||||||
Zathura.Bookmarks.bookmarks[i].id = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].id;
|
Zathura.Bookmarks.bookmarks[i].id = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].id;
|
||||||
Zathura.Bookmarks.bookmarks[i].page = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].page;
|
Zathura.Bookmarks.bookmarks[i].page = Zathura.Bookmarks.bookmarks[Zathura.Bookmarks.number_of_bookmarks - 1].page;
|
||||||
|
@ -3985,8 +4008,16 @@ cb_destroy(GtkWidget* widget, gpointer data)
|
||||||
if(Zathura.PDF.document)
|
if(Zathura.PDF.document)
|
||||||
close_file(FALSE);
|
close_file(FALSE);
|
||||||
|
|
||||||
/* clean up other variables */
|
/* clean up bookmarks */
|
||||||
g_free(Zathura.Bookmarks.file);
|
g_free(Zathura.Bookmarks.file);
|
||||||
|
if (Zathura.Bookmarks.data)
|
||||||
|
g_key_file_free(Zathura.Bookmarks.data);
|
||||||
|
|
||||||
|
/* destroy mutexes */
|
||||||
|
g_static_mutex_free(&(Zathura.Lock.pdflib_lock));
|
||||||
|
g_static_mutex_free(&(Zathura.Lock.search_lock));
|
||||||
|
g_static_mutex_free(&(Zathura.Lock.pdf_obj_lock));
|
||||||
|
g_static_mutex_free(&(Zathura.Lock.select_lock));
|
||||||
|
|
||||||
/* inotify */
|
/* inotify */
|
||||||
if(Zathura.FileMonitor.monitor)
|
if(Zathura.FileMonitor.monitor)
|
||||||
|
|
Loading…
Reference in a new issue