X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=futatabi%2Fflags.cpp;h=c5bc722f5c6fa2eaeb3eecaf24a981da004cf2e8;hb=fcae09355c1a00a68015b3d727339aebd2e52aa4;hp=9e15399aa40189789c67f9e15d1ae49eb4cf8fd7;hpb=c1f1bd35d8c8e2cb9ff97c3535bb2dd04d55a51d;p=nageru diff --git a/futatabi/flags.cpp b/futatabi/flags.cpp index 9e15399..c5bc722 100644 --- a/futatabi/flags.cpp +++ b/futatabi/flags.cpp @@ -4,7 +4,6 @@ #include #include #include - #include using namespace std; @@ -17,7 +16,9 @@ enum LongOption { OPTION_HELP = 1000, OPTION_SLOW_DOWN_INPUT = 1001, OPTION_HTTP_PORT = 1002, - OPTION_TALLY_URL = 1003 + OPTION_TALLY_URL = 1003, + OPTION_CUE_POINT_PADDING = 1004, + OPTION_MIDI_MAPPING = 1005 }; void usage() @@ -36,12 +37,14 @@ 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, " -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"); + fprintf(stderr, " --midi-mapping=FILE start with the given MIDI controller mapping\n"); } -void parse_flags(int argc, char * const argv[]) +void parse_flags(int argc, char *const argv[]) { static const option long_options[] = { { "help", no_argument, 0, OPTION_HELP }, @@ -53,9 +56,11 @@ 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 }, + { "midi-mapping", required_argument, 0, OPTION_MIDI_MAPPING }, { 0, 0, 0, 0 } }; - for ( ;; ) { + for (;;) { int option_index = 0; int c = getopt_long(argc, argv, "w:h:r:q:d:", long_options, &option_index); @@ -97,6 +102,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; + break; + case OPTION_MIDI_MAPPING: + global_flags.midi_mapping_filename = optarg; + break; case OPTION_HELP: usage(); exit(0); @@ -113,4 +125,9 @@ void parse_flags(int argc, char * const argv[]) usage(); exit(1); } + if (global_flags.cue_point_padding_seconds < 0.0) { + fprintf(stderr, "Cue point padding cannot be negative.\n"); + usage(); + exit(1); + } }