diff options
author | Daniel Friesel <derf@derf.homelinux.org> | 2010-05-03 20:12:46 +0200 |
---|---|---|
committer | Daniel Friesel <derf@derf.homelinux.org> | 2010-05-03 20:12:46 +0200 |
commit | 51802b3732716e02a719d2dbd86fbac109851b06 (patch) | |
tree | bbb8d6201361593d9e15a082668686f3d8ff95c5 /src | |
parent | 308031b69cd440534ee076dcaabba93e489b4faf (diff) |
Make --start-at work with filenames instead of list positions
Diffstat (limited to 'src')
-rw-r--r-- | src/options.c | 3 | ||||
-rw-r--r-- | src/options.h | 2 | ||||
-rw-r--r-- | src/slideshow.c | 19 |
3 files changed, 15 insertions, 9 deletions
diff --git a/src/options.c b/src/options.c index 9afa33a..224af59 100644 --- a/src/options.c +++ b/src/options.c @@ -72,6 +72,7 @@ void init_parse_options(int argc, char **argv) opt.blur_button = 1; opt.no_blur_ctrl_mask = 0; + opt.start_list_at = NULL; opt.no_jump_on_resort = 0; opt.builtin_http = 0; @@ -627,7 +628,7 @@ static void feh_parse_option_array(int argc, char **argv) opt.blur_button = atoi(optarg); break; case '|': - opt.start_list_at = atoi(optarg); + opt.start_list_at = estrdup(optarg); break; case 't': opt.thumbs = 1; diff --git a/src/options.h b/src/options.h index 55b997f..4a275e9 100644 --- a/src/options.h +++ b/src/options.h @@ -87,6 +87,7 @@ struct __fehoptions { char *rcfile; char *menu_style; char *caption_path; + char *start_list_at; gib_style *menu_style_l; @@ -119,7 +120,6 @@ struct __fehoptions { int default_zoom; int menu_border; unsigned char adjust_reload; - unsigned int start_list_at; unsigned char mode; unsigned char paused; diff --git a/src/slideshow.c b/src/slideshow.c index 0d509e4..e3791a1 100644 --- a/src/slideshow.c +++ b/src/slideshow.c @@ -34,18 +34,23 @@ void init_slideshow_mode(void) winwidget w = NULL; int success = 0; char *s = NULL; - gib_list *l = NULL, *last = NULL; + gib_list *l = filelist, *last = NULL; feh_file *file = NULL; D_ENTER(3); - mode = "slideshow"; - if (opt.start_list_at) { - l = gib_list_nth(filelist, opt.start_list_at); - opt.start_list_at = 0; /* for next time */ - } else { - l = filelist; + for (l = filelist; l && opt.start_list_at; l = l->next) { + if (!strcmp(opt.start_list_at, FEH_FILE(l->data)->filename)) { + opt.start_list_at = NULL; + break; + } } + + if (opt.start_list_at) + eprintf("--start-at %s: File not found in filelist", + opt.start_list_at); + + mode = "slideshow"; for (; l; l = l->next) { file = FEH_FILE(l->data); if (last) { |