mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-01 08:06:00 +01:00
If a filename contains [ or ] store the filename Base-64 encoded. (Closes: #148)
This commit is contained in:
parent
737f312e6c
commit
b56a7fa73d
1 changed files with 42 additions and 15 deletions
|
@ -72,6 +72,20 @@ enum
|
||||||
PROP_PATH
|
PROP_PATH
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static char*
|
||||||
|
prepare_filename(const char* file)
|
||||||
|
{
|
||||||
|
if (file == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strchr(file, '[') == NULL && strchr(file, ']') == NULL) {
|
||||||
|
return g_strdup(file);
|
||||||
|
}
|
||||||
|
|
||||||
|
return g_base64_encode((const guchar*) file, strlen(file));
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
zathura_database_interface_init(ZathuraDatabaseInterface* iface)
|
zathura_database_interface_init(ZathuraDatabaseInterface* iface)
|
||||||
{
|
{
|
||||||
|
@ -274,7 +288,9 @@ plain_add_bookmark(zathura_database_t* db, const char* file,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_key_file_set_integer(priv->bookmarks, file, bookmark->id, bookmark->page);
|
char* name = prepare_filename(file);
|
||||||
|
g_key_file_set_integer(priv->bookmarks, name, bookmark->id, bookmark->page);
|
||||||
|
g_free(name);
|
||||||
|
|
||||||
zathura_db_write_key_file_to_file(priv->bookmark_path, priv->bookmarks);
|
zathura_db_write_key_file_to_file(priv->bookmark_path, priv->bookmarks);
|
||||||
|
|
||||||
|
@ -290,13 +306,16 @@ plain_remove_bookmark(zathura_database_t* db, const char* file, const char*
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_key_file_has_group(priv->bookmarks, file) == TRUE) {
|
char* name = prepare_filename(file);
|
||||||
g_key_file_remove_group(priv->bookmarks, file, NULL);
|
if (g_key_file_has_group(priv->bookmarks, name) == TRUE) {
|
||||||
|
g_key_file_remove_group(priv->bookmarks, name, NULL);
|
||||||
|
|
||||||
zathura_db_write_key_file_to_file(priv->bookmark_path, priv->bookmarks);
|
zathura_db_write_key_file_to_file(priv->bookmark_path, priv->bookmarks);
|
||||||
|
g_free(name);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
g_free(name);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -309,7 +328,9 @@ plain_load_bookmarks(zathura_database_t* db, const char* file)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_key_file_has_group(priv->bookmarks, file) == FALSE) {
|
char* name = prepare_filename(file);
|
||||||
|
if (g_key_file_has_group(priv->bookmarks, name) == FALSE) {
|
||||||
|
g_free(name);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -318,9 +339,10 @@ plain_load_bookmarks(zathura_database_t* db, const char* file)
|
||||||
zathura_bookmark_free);
|
zathura_bookmark_free);
|
||||||
|
|
||||||
gsize length;
|
gsize length;
|
||||||
char** keys = g_key_file_get_keys(priv->bookmarks, file, &length, NULL);
|
char** keys = g_key_file_get_keys(priv->bookmarks, name, &length, NULL);
|
||||||
if (keys == NULL) {
|
if (keys == NULL) {
|
||||||
girara_list_free(result);
|
girara_list_free(result);
|
||||||
|
g_free(name);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -328,11 +350,12 @@ plain_load_bookmarks(zathura_database_t* db, const char* file)
|
||||||
zathura_bookmark_t* bookmark = g_malloc0(sizeof(zathura_bookmark_t));
|
zathura_bookmark_t* bookmark = g_malloc0(sizeof(zathura_bookmark_t));
|
||||||
|
|
||||||
bookmark->id = g_strdup(keys[i]);
|
bookmark->id = g_strdup(keys[i]);
|
||||||
bookmark->page = g_key_file_get_integer(priv->bookmarks, file, keys[i], NULL);
|
bookmark->page = g_key_file_get_integer(priv->bookmarks, name, keys[i], NULL);
|
||||||
|
|
||||||
girara_list_append(result, bookmark);
|
girara_list_append(result, bookmark);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g_free(name);
|
||||||
g_strfreev(keys);
|
g_strfreev(keys);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
@ -348,12 +371,14 @@ plain_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
||||||
}
|
}
|
||||||
|
|
||||||
char* tmp = g_strdup_printf("%f", scale);
|
char* tmp = g_strdup_printf("%f", scale);
|
||||||
|
char* name = prepare_filename(file);
|
||||||
|
|
||||||
g_key_file_set_integer(priv->history, file, KEY_PAGE, page);
|
g_key_file_set_integer(priv->history, name, KEY_PAGE, page);
|
||||||
g_key_file_set_integer(priv->history, file, KEY_OFFSET, offset);
|
g_key_file_set_integer(priv->history, name, KEY_OFFSET, offset);
|
||||||
g_key_file_set_string (priv->history, file, KEY_SCALE, tmp);
|
g_key_file_set_string (priv->history, name, KEY_SCALE, tmp);
|
||||||
g_key_file_set_integer(priv->history, file, KEY_ROTATE, rotation);
|
g_key_file_set_integer(priv->history, name, KEY_ROTATE, rotation);
|
||||||
|
|
||||||
|
g_free(name);
|
||||||
g_free(tmp);
|
g_free(tmp);
|
||||||
|
|
||||||
zathura_db_write_key_file_to_file(priv->history_path, priv->history);
|
zathura_db_write_key_file_to_file(priv->history_path, priv->history);
|
||||||
|
@ -370,17 +395,19 @@ plain_get_fileinfo(zathura_database_t* db, const char* file, unsigned int*
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_key_file_has_group(priv->history, file) == FALSE) {
|
char* name = prepare_filename(file);
|
||||||
|
if (g_key_file_has_group(priv->history, name) == FALSE) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
*page = g_key_file_get_integer(priv->history, file, KEY_PAGE, NULL);
|
*page = g_key_file_get_integer(priv->history, name, KEY_PAGE, NULL);
|
||||||
*offset = g_key_file_get_integer(priv->history, file, KEY_OFFSET, NULL);
|
*offset = g_key_file_get_integer(priv->history, name, KEY_OFFSET, NULL);
|
||||||
*rotation = g_key_file_get_integer(priv->history, file, KEY_ROTATE, NULL);
|
*rotation = g_key_file_get_integer(priv->history, name, KEY_ROTATE, NULL);
|
||||||
|
|
||||||
char* scale_string = g_key_file_get_string(priv->history, file, KEY_SCALE, NULL);
|
char* scale_string = g_key_file_get_string(priv->history, name, KEY_SCALE, NULL);
|
||||||
*scale = strtod(scale_string, NULL);
|
*scale = strtod(scale_string, NULL);
|
||||||
g_free(scale_string);
|
g_free(scale_string);
|
||||||
|
g_free(name);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue