Check all given files before open the first
This commit is contained in:
parent
004f297ebb
commit
a732e75d8a
12
image.c
12
image.c
@ -39,22 +39,26 @@ void imlib_destroy() {
|
|||||||
imlib_free_image();
|
imlib_free_image();
|
||||||
}
|
}
|
||||||
|
|
||||||
void img_load(img_t *img, const char *filename) {
|
int img_load(img_t *img, const char *filename) {
|
||||||
Imlib_Image *im;
|
Imlib_Image *im;
|
||||||
|
|
||||||
if (!img || !filename)
|
if (!img || !filename)
|
||||||
return;
|
return -1;
|
||||||
|
|
||||||
if (imlib_context_get_image())
|
if (imlib_context_get_image())
|
||||||
imlib_free_image();
|
imlib_free_image();
|
||||||
|
|
||||||
if (!(im = imlib_load_image(filename)))
|
if (!(im = imlib_load_image(filename))) {
|
||||||
DIE("could not open image: %s", filename);
|
WARN("could not open image: %s", filename);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
imlib_context_set_image(im);
|
imlib_context_set_image(im);
|
||||||
|
|
||||||
img->w = imlib_image_get_width();
|
img->w = imlib_image_get_width();
|
||||||
img->h = imlib_image_get_height();
|
img->h = imlib_image_get_height();
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void img_display(img_t *img, win_t *win) {
|
void img_display(img_t *img, win_t *win) {
|
||||||
|
2
image.h
2
image.h
@ -39,7 +39,7 @@ typedef struct img_s {
|
|||||||
void imlib_init(win_t*);
|
void imlib_init(win_t*);
|
||||||
void imlib_destroy();
|
void imlib_destroy();
|
||||||
|
|
||||||
void img_load(img_t*, const char*);
|
int img_load(img_t*, const char*);
|
||||||
void img_display(img_t*, win_t*);
|
void img_display(img_t*, win_t*);
|
||||||
void img_render(img_t*, win_t*, int, int, int, int);
|
void img_render(img_t*, win_t*, int, int, int, int);
|
||||||
|
|
||||||
|
28
main.c
28
main.c
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
#include <X11/keysym.h>
|
#include <X11/keysym.h>
|
||||||
@ -38,6 +39,9 @@ static void (*handler[LASTEvent])(XEvent*) = {
|
|||||||
|
|
||||||
img_t img;
|
img_t img;
|
||||||
win_t win;
|
win_t win;
|
||||||
|
|
||||||
|
const char **filenames;
|
||||||
|
unsigned int filecnt;
|
||||||
unsigned int fileidx;
|
unsigned int fileidx;
|
||||||
|
|
||||||
void run() {
|
void run() {
|
||||||
@ -50,6 +54,8 @@ void run() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
|
int i;
|
||||||
|
|
||||||
parse_options(argc, argv);
|
parse_options(argc, argv);
|
||||||
|
|
||||||
if (!options->filecnt) {
|
if (!options->filecnt) {
|
||||||
@ -57,7 +63,21 @@ int main(int argc, char **argv) {
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!(filenames = (const char**) malloc(options->filecnt * sizeof(char*))))
|
||||||
|
DIE("could not allocate memory");
|
||||||
|
|
||||||
fileidx = 0;
|
fileidx = 0;
|
||||||
|
filecnt = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < options->filecnt; ++i) {
|
||||||
|
if (!(img_load(&img, options->filenames[i]) < 0))
|
||||||
|
filenames[filecnt++] = options->filenames[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!filecnt) {
|
||||||
|
fprintf(stderr, "sxiv: no valid image filename given, aborting\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
img.zoom = 1.0;
|
img.zoom = 1.0;
|
||||||
img.scalemode = SCALE_MODE;
|
img.scalemode = SCALE_MODE;
|
||||||
@ -68,7 +88,7 @@ int main(int argc, char **argv) {
|
|||||||
win_open(&win);
|
win_open(&win);
|
||||||
imlib_init(&win);
|
imlib_init(&win);
|
||||||
|
|
||||||
img_load(&img, options->filenames[fileidx]);
|
img_load(&img, filenames[fileidx]);
|
||||||
img_display(&img, &win);
|
img_display(&img, &win);
|
||||||
|
|
||||||
run();
|
run();
|
||||||
@ -104,15 +124,15 @@ void on_keypress(XEvent *ev) {
|
|||||||
exit(0);
|
exit(0);
|
||||||
case XK_n:
|
case XK_n:
|
||||||
case XK_space:
|
case XK_space:
|
||||||
if (fileidx + 1 < options->filecnt) {
|
if (fileidx + 1 < filecnt) {
|
||||||
img_load(&img, options->filenames[++fileidx]);
|
img_load(&img, filenames[++fileidx]);
|
||||||
img_display(&img, &win);
|
img_display(&img, &win);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case XK_p:
|
case XK_p:
|
||||||
case XK_BackSpace:
|
case XK_BackSpace:
|
||||||
if (fileidx > 0) {
|
if (fileidx > 0) {
|
||||||
img_load(&img, options->filenames[--fileidx]);
|
img_load(&img, filenames[--fileidx]);
|
||||||
img_display(&img, &win);
|
img_display(&img, &win);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user