X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=futatabi%2Fflags.cpp;h=eea7c0700358f2752318e9d0d18fa56eff536d47;hb=3ffbf49e7053bc419f5440bbde139e282dd73a8b;hp=c5bc722f5c6fa2eaeb3eecaf24a981da004cf2e8;hpb=a6f3a2275ad116e6ab338e583ab8ef1b1141b468;p=nageru diff --git a/futatabi/flags.cpp b/futatabi/flags.cpp index c5bc722..eea7c07 100644 --- a/futatabi/flags.cpp +++ b/futatabi/flags.cpp @@ -17,8 +17,9 @@ enum LongOption { OPTION_SLOW_DOWN_INPUT = 1001, OPTION_HTTP_PORT = 1002, OPTION_TALLY_URL = 1003, - OPTION_CUE_POINT_PADDING = 1004, - OPTION_MIDI_MAPPING = 1005 + OPTION_CUE_IN_POINT_PADDING = 1004, + OPTION_CUE_OUT_POINT_PADDING = 1005, + OPTION_MIDI_MAPPING = 1006 }; void usage() @@ -37,7 +38,8 @@ void usage() fprintf(stderr, " 2 = default (realtime 720p on fast embedded GPUs)\n"); fprintf(stderr, " 3 = good (realtime 720p on GTX 970 or so)\n"); fprintf(stderr, " 4 = best (not realtime on any current GPU)\n"); - fprintf(stderr, " --cue-point-padding SECS move cue-in/cue-out N seconds earlier/later on set\n"); + fprintf(stderr, " --cue-in-point-padding SECS move cue-in N seconds earlier on set\n"); + fprintf(stderr, " --cue-out-point-padding SECS move cue-out N seconds later on set\n"); fprintf(stderr, " -d, --working-directory DIR where to store frames and database\n"); fprintf(stderr, " --http-port PORT which port to listen on for output\n"); fprintf(stderr, " --tally-url URL URL to get tally color from (polled every 100 ms)\n"); @@ -56,7 +58,8 @@ void parse_flags(int argc, char *const argv[]) { "working-directory", required_argument, 0, 'd' }, { "http-port", required_argument, 0, OPTION_HTTP_PORT }, { "tally-url", required_argument, 0, OPTION_TALLY_URL }, - { "cue-point-padding", required_argument, 0, OPTION_CUE_POINT_PADDING }, + { "cue-in-point-padding", required_argument, 0, OPTION_CUE_IN_POINT_PADDING }, + { "cue-out-point-padding", required_argument, 0, OPTION_CUE_OUT_POINT_PADDING }, { "midi-mapping", required_argument, 0, OPTION_MIDI_MAPPING }, { 0, 0, 0, 0 } }; @@ -82,7 +85,7 @@ void parse_flags(int argc, char *const argv[]) global_flags.output_framerate = num; } else { fprintf(stderr, "Invalid frame rate given (must be on the form N or N/M)\n"); - exit(1); + abort(); } break; } @@ -102,9 +105,13 @@ void parse_flags(int argc, char *const argv[]) case OPTION_TALLY_URL: global_flags.tally_url = optarg; break; - case OPTION_CUE_POINT_PADDING: - global_flags.cue_point_padding_seconds = atof(optarg); - global_flags.cue_point_padding_set = true; + case OPTION_CUE_IN_POINT_PADDING: + global_flags.cue_in_point_padding_seconds = atof(optarg); + global_flags.cue_in_point_padding_set = true; + break; + case OPTION_CUE_OUT_POINT_PADDING: + global_flags.cue_out_point_padding_seconds = atof(optarg); + global_flags.cue_out_point_padding_set = true; break; case OPTION_MIDI_MAPPING: global_flags.midi_mapping_filename = optarg; @@ -116,18 +123,19 @@ void parse_flags(int argc, char *const argv[]) fprintf(stderr, "Unknown option '%s'\n", argv[option_index]); fprintf(stderr, "\n"); usage(); - exit(1); + abort(); } } if (global_flags.interpolation_quality < 0 || global_flags.interpolation_quality > 4) { fprintf(stderr, "Interpolation quality must be 0, 1, 2, 3 or 4.\n"); usage(); - exit(1); + abort(); } - if (global_flags.cue_point_padding_seconds < 0.0) { + if (global_flags.cue_in_point_padding_seconds < 0.0 || + global_flags.cue_out_point_padding_seconds < 0.0) { fprintf(stderr, "Cue point padding cannot be negative.\n"); usage(); - exit(1); + abort(); } }