Fixed opening files containing spaces

Now it is possible to open files even if the contain white spaces. If
they do need a password, you can set it with the command: ":set password"
or specify it on startup: "./zathura file password".
This commit is contained in:
Moritz Lipp 2010-02-02 15:27:37 +01:00
parent 0c5f0dfb0c
commit 2b072aa896
2 changed files with 111 additions and 81 deletions

View file

@ -136,4 +136,5 @@ SpecialCommand special_commands[] = {
Setting settings[] = { Setting settings[] = {
/* name, variable, type, render, description */ /* name, variable, type, render, description */
{"revertvideo", &(Zathura.Global.reverse_video), 'b', TRUE, "Invert the image"}, {"revertvideo", &(Zathura.Global.reverse_video), 'b', TRUE, "Invert the image"},
{"password", &(Zathura.PDF.password), 's', FALSE, "The password of the document"},
}; };

191
zathura.c
View file

@ -227,6 +227,7 @@ struct
{ {
PopplerDocument *document; PopplerDocument *document;
char *file; char *file;
char *password;
Page **pages; Page **pages;
int page_number; int page_number;
int number_of_pages; int number_of_pages;
@ -247,6 +248,7 @@ void highlight_result(int, PopplerRectangle*);
void draw(int); void draw(int);
void eval_marker(int); void eval_marker(int);
void notify(int, char*); void notify(int, char*);
gboolean open_file(char*, char*);
void update_status(); void update_status();
void recalcRectangle(int, PopplerRectangle*); void recalcRectangle(int, PopplerRectangle*);
void setCompletionRowColor(GtkBox*, int, int); void setCompletionRowColor(GtkBox*, int, int);
@ -725,6 +727,103 @@ void notify(int level, char* message)
gtk_entry_set_text(Zathura.UI.inputbar, message); gtk_entry_set_text(Zathura.UI.inputbar, message);
} }
gboolean
open_file(char* path, char* password)
{
/* get filename */
char* file = realpath(path, NULL);
if(path[0] == '~')
file = g_strdup_printf("%s%s", getenv("HOME"), path + 1);
/* check if file exists */
if(!g_file_test(file, G_FILE_TEST_IS_REGULAR))
{
notify(ERROR, "File does not exist");
return FALSE;
}
/* close old file */
cmd_close(-1, NULL);
/* check saved password */
if(!password)
password = (Zathura.PDF.password && strlen(Zathura.PDF.password) != 0) ? Zathura.PDF.password : NULL;
/* open file */
GError* error = NULL;
Zathura.PDF.document = poppler_document_new_from_file(g_strdup_printf("file://%s", file),
password ? password : NULL, &error);
if(!Zathura.PDF.document)
{
char* message = (error->code == 1) ? "(Use \":set password\" to set the password)" : "";
message = g_strdup_printf("Can not open file: %s %s", error->message, message);
notify(ERROR, message);
g_free(message);
g_error_free(error);
return FALSE;
}
Zathura.PDF.number_of_pages = poppler_document_get_n_pages(Zathura.PDF.document);
Zathura.PDF.file = file;
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
Zathura.PDF.scale = 100;
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
pthread_mutex_lock(&(Zathura.Lock.rotate_lock));
Zathura.PDF.rotate = 0;
pthread_mutex_unlock(&(Zathura.Lock.rotate_lock));
Zathura.PDF.pages = malloc(Zathura.PDF.number_of_pages * sizeof(Page*));
Zathura.State.filename = file;
/* get pages */
int i;
for(i = 0; i < Zathura.PDF.number_of_pages; i++)
{
Zathura.PDF.pages[i] = malloc(sizeof(Page));
Zathura.PDF.pages[i]->page = poppler_document_get_page(Zathura.PDF.document, i);
pthread_mutex_init(&(Zathura.PDF.pages[i]->lock), NULL);
}
/* start page */
int start_page = 0;
/* bookmarks */
if(Zathura.Bookmarks.data)
{
/* get last opened page */
if(g_key_file_has_group(Zathura.Bookmarks.data, file))
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);
/* 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);
update_status();
return TRUE;
}
void void
update_status() update_status()
{ {
@ -1665,6 +1764,7 @@ cmd_close(int argc, char** argv)
Zathura.State.filename = (char*) DEFAULT_TEXT; Zathura.State.filename = (char*) DEFAULT_TEXT;
Zathura.PDF.document = NULL; Zathura.PDF.document = NULL;
Zathura.PDF.file = ""; Zathura.PDF.file = "";
Zathura.PDF.password = "";
Zathura.PDF.page_number = 0; Zathura.PDF.page_number = 0;
Zathura.PDF.number_of_pages = 0; Zathura.PDF.number_of_pages = 0;
Zathura.PDF.scale = 0; Zathura.PDF.scale = 0;
@ -1918,89 +2018,18 @@ cmd_open(int argc, char** argv)
if(argc == 0 || strlen(argv[0]) == 0) if(argc == 0 || strlen(argv[0]) == 0)
return FALSE; return FALSE;
/* get filename */ /* assembly the arguments back to one string */
char* file = realpath(argv[0], NULL); int i = 0;
GString *filepath = g_string_new("");
if(argv[0][0] == '~') for(i = 0; i < argc; i++)
file = g_strdup_printf("%s%s", getenv("HOME"), argv[0] + 1);
/* check if file exists */
if(!g_file_test(file, G_FILE_TEST_IS_REGULAR))
{ {
notify(ERROR, "File does not exist"); if(i != 0)
return FALSE; filepath = g_string_append_c(filepath, ' ');
filepath = g_string_append(filepath, argv[i]);
} }
/* close old file */ return open_file(filepath->str, Zathura.PDF.password);
cmd_close(-1, NULL);
/* open file */
Zathura.PDF.document = poppler_document_new_from_file(g_strdup_printf("file://%s", file),
(argc == 2) ? argv[1] : NULL, NULL);
if(!Zathura.PDF.document)
{
notify(ERROR, "Can not open file");
return FALSE;
}
Zathura.PDF.number_of_pages = poppler_document_get_n_pages(Zathura.PDF.document);
Zathura.PDF.file = file;
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
Zathura.PDF.scale = 100;
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
pthread_mutex_lock(&(Zathura.Lock.rotate_lock));
Zathura.PDF.rotate = 0;
pthread_mutex_unlock(&(Zathura.Lock.rotate_lock));
Zathura.PDF.pages = malloc(Zathura.PDF.number_of_pages * sizeof(Page*));
Zathura.State.filename = file;
/* get pages */
int i;
for(i = 0; i < Zathura.PDF.number_of_pages; i++)
{
Zathura.PDF.pages[i] = malloc(sizeof(Page));
Zathura.PDF.pages[i]->page = poppler_document_get_page(Zathura.PDF.document, i);
pthread_mutex_init(&(Zathura.PDF.pages[i]->lock), NULL);
}
/* start page */
int start_page = 0;
/* bookmarks */
if(Zathura.Bookmarks.data)
{
/* get last opened page */
if(g_key_file_has_group(Zathura.Bookmarks.data, file))
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);
/* 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);
update_status();
return TRUE;
} }
gboolean gboolean
@ -2747,7 +2776,7 @@ int main(int argc, char* argv[])
update_status(); update_status();
if(argc >= 2) if(argc >= 2)
cmd_open(2, &argv[1]); open_file(argv[1], (argc == 3) ? argv[2] : NULL);
gtk_widget_show_all(GTK_WIDGET(Zathura.UI.window)); gtk_widget_show_all(GTK_WIDGET(Zathura.UI.window));