zeniba-nsxiv/options.c

199 lines
5 KiB
C
Raw Normal View History

2013-02-08 21:52:41 +01:00
/* Copyright 2011 Bert Muennich
2011-01-17 14:57:59 +01:00
*
* This file is a part of nsxiv.
*
* nsxiv is free software; you can redistribute it and/or modify
2013-02-08 21:52:41 +01:00
* it under the terms of the GNU General Public License as published
* by the Free Software Foundation; either version 2 of the License,
* or (at your option) any later version.
*
* nsxiv is distributed in the hope that it will be useful,
2013-02-08 21:52:41 +01:00
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with nsxiv. If not, see <http://www.gnu.org/licenses/>.
2011-01-17 14:57:59 +01:00
*/
#include "nsxiv.h"
#define _IMAGE_CONFIG
#define _TITLE_CONFIG
#include "config.h"
#include "version.h"
#include <stdlib.h>
2011-02-14 17:51:04 +01:00
#include <string.h>
#include <unistd.h>
2011-01-17 16:40:54 +01:00
opt_t _options;
const opt_t *options = (const opt_t*) &_options;
2011-01-17 16:40:54 +01:00
void print_usage(void)
{
2021-09-21 22:33:06 +02:00
printf("usage: nsxiv [-abcfhi0opqrtvZ] [-A FRAMERATE] [-e WID] [-G GAMMA] "
"[-g GEOMETRY] [-N NAME] [-T TITLE] [-n NUM] [-S DELAY] [-s MODE] "
"[-z ZOOM] FILES...\n");
2011-01-17 16:40:54 +01:00
}
void print_version(void)
{
puts("nsxiv " VERSION);
2011-01-17 16:40:54 +01:00
}
2011-01-18 17:20:41 +01:00
void parse_options(int argc, char **argv)
{
int n, opt;
char *end, *s;
2021-04-14 19:10:14 +02:00
const char *scalemodes = "dfFwh";
2011-05-25 09:23:23 +02:00
progname = strrchr(argv[0], '/');
progname = progname ? progname + 1 : argv[0];
_options.from_stdin = false;
_options.to_stdout = false;
_options.stdout_separator = '\n';
2011-09-11 21:01:24 +02:00
_options.recursive = false;
2011-05-25 09:23:23 +02:00
_options.startnum = 0;
_options.scalemode = SCALE_DOWN;
2011-01-28 13:34:16 +01:00
_options.zoom = 1.0;
_options.animate = false;
_options.gamma = 0;
_options.slideshow = 0;
_options.framerate = 0;
2011-01-28 13:34:16 +01:00
2011-09-11 21:01:24 +02:00
_options.fullscreen = false;
_options.embed = 0;
2012-02-16 23:20:27 +01:00
_options.hide_bar = false;
_options.geometry = NULL;
_options.res_name = NULL;
_options.title_prefix = TITLE_PREFIX;
_options.title_suffixmode = TITLE_SUFFIXMODE;
2011-01-27 16:15:43 +01:00
2011-09-11 21:01:24 +02:00
_options.quiet = false;
_options.thumb_mode = false;
_options.clean_cache = false;
_options.private_mode = false;
2011-01-30 16:39:16 +01:00
while ((opt = getopt(argc, argv, "A:abce:fG:g:hin:N:0opqrS:s:T:tvZz:")) != -1) {
switch (opt) {
case '?':
2011-01-19 18:16:44 +01:00
print_usage();
2011-09-26 15:40:07 +02:00
exit(EXIT_FAILURE);
case 'A':
n = strtol(optarg, &end, 0);
if (*end != '\0' || n <= 0)
error(EXIT_FAILURE, 0, "Invalid argument for option -A: %s", optarg);
_options.framerate = n;
2016-11-28 18:54:39 +01:00
/* fall through */
case 'a':
_options.animate = true;
break;
2012-02-16 23:20:27 +01:00
case 'b':
_options.hide_bar = true;
break;
2011-04-11 21:27:20 +02:00
case 'c':
2011-09-11 21:01:24 +02:00
_options.clean_cache = true;
2011-04-08 14:44:00 +02:00
break;
2016-10-30 19:10:25 +01:00
case 'e':
n = strtol(optarg, &end, 0);
if (*end != '\0')
error(EXIT_FAILURE, 0, "Invalid argument for option -e: %s", optarg);
_options.embed = n;
break;
2011-01-28 13:34:16 +01:00
case 'f':
2011-09-11 21:01:24 +02:00
_options.fullscreen = true;
2011-01-28 13:34:16 +01:00
break;
case 'G':
n = strtol(optarg, &end, 0);
if (*end != '\0')
error(EXIT_FAILURE, 0, "Invalid argument for option -G: %s", optarg);
_options.gamma = n;
break;
2013-11-14 17:06:20 +01:00
case 'g':
_options.geometry = optarg;
break;
case 'h':
print_usage();
2011-09-26 15:40:07 +02:00
exit(EXIT_SUCCESS);
case 'i':
_options.from_stdin = true;
break;
2011-05-25 09:23:23 +02:00
case 'n':
n = strtol(optarg, &end, 0);
if (*end != '\0' || n <= 0)
error(EXIT_FAILURE, 0, "Invalid argument for option -n: %s", optarg);
_options.startnum = n - 1;
2011-05-25 09:23:23 +02:00
break;
case 'N':
_options.res_name = optarg;
break;
case '0':
_options.stdout_separator = '\0';
/* -0 implies -o */
/* fall through */
case 'o':
_options.to_stdout = true;
break;
case 'p':
_options.private_mode = true;
break;
case 'q':
2011-09-11 21:01:24 +02:00
_options.quiet = true;
break;
case 'r':
2011-09-11 21:01:24 +02:00
_options.recursive = true;
break;
case 'S':
2016-12-01 20:33:24 +01:00
n = strtof(optarg, &end) * 10;
if (*end != '\0' || n <= 0)
error(EXIT_FAILURE, 0, "Invalid argument for option -S: %s", optarg);
_options.slideshow = n;
break;
2011-01-28 13:34:16 +01:00
case 's':
s = strchr(scalemodes, optarg[0]);
if (s == NULL || *s == '\0' || strlen(optarg) != 1)
error(EXIT_FAILURE, 0, "Invalid argument for option -s: %s", optarg);
_options.scalemode = s - scalemodes;
2011-01-28 13:34:16 +01:00
break;
case 'T':
if ((s = strrchr(optarg, ':')) != NULL) {
*s = '\0';
n = strtol(++s, &end, 0);
if (*end != '\0' || n < SUFFIX_EMPTY || n > SUFFIX_FULLPATH)
error(EXIT_FAILURE, 0, "Invalid argument for option -T suffixmode: %s", s);
_options.title_suffixmode = n;
}
_options.title_prefix = optarg;
break;
2011-02-16 16:47:12 +01:00
case 't':
2011-09-11 21:01:24 +02:00
_options.thumb_mode = true;
2011-02-16 16:47:12 +01:00
break;
case 'v':
print_version();
2011-09-26 15:40:07 +02:00
exit(EXIT_SUCCESS);
2011-01-28 13:34:16 +01:00
case 'Z':
_options.scalemode = SCALE_ZOOM;
_options.zoom = 1.0;
break;
case 'z':
n = strtol(optarg, &end, 0);
if (*end != '\0' || n <= 0)
error(EXIT_FAILURE, 0, "Invalid argument for option -z: %s", optarg);
_options.scalemode = SCALE_ZOOM;
_options.zoom = (float) n / 100.0;
2011-01-28 13:34:16 +01:00
break;
}
}
2011-01-20 16:03:59 +01:00
2011-05-29 11:45:58 +02:00
_options.filenames = argv + optind;
2011-01-20 16:03:59 +01:00
_options.filecnt = argc - optind;
if (_options.filecnt == 1 && STREQ(_options.filenames[0], "-")) {
_options.filenames++;
_options.filecnt--;
_options.from_stdin = true;
}
2011-01-18 17:20:41 +01:00
}