mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-04 00:05:59 +01:00
Get file info earlier
We need to know the document's 'scale' value earlier (before cairo surfaces are created). Otherwise, cairo surfaces will be re-created and wrong page will be rendered (since zoom doesn't preserve page number). Signed-off-by: Pavel Borzenkov <pavel.borzenkov@gmail.com> Signed-off-by: Sebastian Ramacher <s.ramacher@gmx.at>
This commit is contained in:
parent
88be07272f
commit
8608823613
5 changed files with 14 additions and 16 deletions
|
@ -223,7 +223,7 @@ zathura_db_load_bookmarks(zathura_database_t* db, const char* file)
|
||||||
|
|
||||||
bool
|
bool
|
||||||
zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
||||||
page, int offset, float scale)
|
page, int offset, double scale)
|
||||||
{
|
{
|
||||||
if (db == NULL || db->history == NULL || file == NULL) {
|
if (db == NULL || db->history == NULL || file == NULL) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -247,7 +247,7 @@ zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
||||||
|
|
||||||
bool
|
bool
|
||||||
zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned int*
|
zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned int*
|
||||||
page, int* offset, float* scale)
|
page, int* offset, double* scale)
|
||||||
{
|
{
|
||||||
if (db == NULL || db->history == NULL || file == NULL || page == NULL ||
|
if (db == NULL || db->history == NULL || file == NULL || page == NULL ||
|
||||||
offset == NULL || scale == NULL) {
|
offset == NULL || scale == NULL) {
|
||||||
|
@ -260,7 +260,7 @@ zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned int*
|
||||||
|
|
||||||
*page = g_key_file_get_integer(db->history, file, KEY_PAGE, NULL);
|
*page = g_key_file_get_integer(db->history, file, KEY_PAGE, NULL);
|
||||||
*offset = g_key_file_get_integer(db->history, file, KEY_OFFSET, NULL);
|
*offset = g_key_file_get_integer(db->history, file, KEY_OFFSET, NULL);
|
||||||
*scale = strtof(g_key_file_get_string(db->history, file, KEY_SCALE, NULL), NULL);
|
*scale = strtod(g_key_file_get_string(db->history, file, KEY_SCALE, NULL), NULL);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -197,7 +197,7 @@ zathura_db_load_bookmarks(zathura_database_t* db, const char* file)
|
||||||
|
|
||||||
bool
|
bool
|
||||||
zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
||||||
page, int offset, float scale)
|
page, int offset, double scale)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail(db && file, false);
|
g_return_val_if_fail(db && file, false);
|
||||||
|
|
||||||
|
@ -225,7 +225,7 @@ zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned int
|
||||||
|
|
||||||
bool
|
bool
|
||||||
zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned int*
|
zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned int*
|
||||||
page, int* offset, float* scale)
|
page, int* offset, double* scale)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail(db && file && page && offset && scale, false);
|
g_return_val_if_fail(db && file && page && offset && scale, false);
|
||||||
|
|
||||||
|
|
|
@ -61,7 +61,7 @@ girara_list_t* zathura_db_load_bookmarks(zathura_database_t* db, const char*
|
||||||
* @return true on success, false otherwise.
|
* @return true on success, false otherwise.
|
||||||
*/
|
*/
|
||||||
bool zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned
|
bool zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned
|
||||||
int page, int offset, float scale);
|
int page, int offset, double scale);
|
||||||
|
|
||||||
/* Get file info (last site, ...) from the database.
|
/* Get file info (last site, ...) from the database.
|
||||||
* @param db The database instance
|
* @param db The database instance
|
||||||
|
@ -72,6 +72,6 @@ bool zathura_db_set_fileinfo(zathura_database_t* db, const char* file, unsigned
|
||||||
* @return true on success, false otherwise.
|
* @return true on success, false otherwise.
|
||||||
*/
|
*/
|
||||||
bool zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned
|
bool zathura_db_get_fileinfo(zathura_database_t* db, const char* file, unsigned
|
||||||
int* page, int* offset, float* scale);
|
int* page, int* offset, double* scale);
|
||||||
|
|
||||||
#endif // DATABASE_H
|
#endif // DATABASE_H
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "zathura.h"
|
#include "zathura.h"
|
||||||
#include "render.h"
|
#include "render.h"
|
||||||
#include "utils.h"
|
#include "database.h"
|
||||||
|
|
||||||
void
|
void
|
||||||
zathura_document_plugins_load(zathura_t* zathura)
|
zathura_document_plugins_load(zathura_t* zathura)
|
||||||
|
@ -218,6 +218,10 @@ zathura_document_open(zathura_t* zathura, const char* path, const char* password
|
||||||
document->scale = 1.0;
|
document->scale = 1.0;
|
||||||
document->zathura = zathura;
|
document->zathura = zathura;
|
||||||
|
|
||||||
|
int offset = 0;
|
||||||
|
zathura_db_get_fileinfo(zathura->database, document->file_path,
|
||||||
|
&document->current_page_number, &offset, &document->scale);
|
||||||
|
|
||||||
if (plugin->open_function != NULL) {
|
if (plugin->open_function != NULL) {
|
||||||
if (plugin->open_function(document) == true) {
|
if (plugin->open_function(document) == true) {
|
||||||
/* update statusbar */
|
/* update statusbar */
|
||||||
|
|
10
zathura.c
10
zathura.c
|
@ -335,13 +335,7 @@ document_open(zathura_t* zathura, const char* path, const char* password)
|
||||||
girara_warning("Failed to load bookmarks for %s.\n", zathura->document->file_path);
|
girara_warning("Failed to load bookmarks for %s.\n", zathura->document->file_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int page = 0u;
|
page_set_delayed(zathura, document->current_page_number - 1);
|
||||||
int offset = 0;
|
|
||||||
float scale = 1.0f;
|
|
||||||
if (zathura_db_get_fileinfo(zathura->database, zathura->document->file_path, &page, &offset, &scale)) {
|
|
||||||
page_set_delayed(zathura, page - 1);
|
|
||||||
zathura->document->scale = scale;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
@ -533,7 +527,7 @@ int main(int argc, char* argv[])
|
||||||
|
|
||||||
zathura_t* zathura = zathura_init(argc, argv);
|
zathura_t* zathura = zathura_init(argc, argv);
|
||||||
if (zathura == NULL) {
|
if (zathura == NULL) {
|
||||||
printf("error: coult not initialize zathura\n");
|
printf("error: could not initialize zathura\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue