# HG changeset patch # User Mychaela Falconia # Date 1490466997 0 # Node ID b002c7cf5d0365ff91928392d97856006d6b017b # Parent 17523db6d1dc2bd3c029acffc8a36f5c83188b3e fc-e1gen: support parenthesized options for bit0 and dummy time byte diff -r 17523db6d1dc -r b002c7cf5d03 ringtools/fc-e1gen.c --- a/ringtools/fc-e1gen.c Thu Mar 23 16:05:55 2017 +0000 +++ b/ringtools/fc-e1gen.c Sat Mar 25 18:36:37 2017 +0000 @@ -82,6 +82,24 @@ return val; } +input_paren_number(str, min, max) + char *str; +{ + char *cp; + + if (str[0] != '(') { +badparen: fprintf(stderr, + "%s line %d: bad parenthesized argument \"%s\"\n", + infname, lineno, str); + exit(1); + } + cp = index(str, ')'); + if (!cp || cp[1]) + goto badparen; + *cp = '\0'; + return input_number(str + 1, min, max); +} + handle_time_line() { if (nfields != 2) { @@ -109,6 +127,7 @@ int amp, freq, length; int tremT0, tremFreq; int sustain, t1, t2, t3, t5; + int bit0; check_req_field(p); oscn = input_number(fields[p], 0, 7); @@ -123,6 +142,12 @@ /* basic part */ check_req_field(p); + if (fields[p][0] == '(') { + bit0 = input_paren_number(fields[p], 0, 1); + p++; + check_req_field(p); + } else + bit0 = 0; if (!strcmp(fields[p], "df")) { p++; check_req_field(p); @@ -131,10 +156,10 @@ check_req_field(p); amp = input_number(fields[p], 0, 1023); p++; - word0 = freq << 2 | 2; + word0 = freq << 2 | 2 | bit0; word1 = amp << 6; } else { - word0 = 0; + word0 = bit0; if (!strcmp(fields[p], "sq1")) { p++; word0 |= 4; @@ -250,6 +275,7 @@ { int p; int oscn, osc_bit; + int dummy_time_byte; do get_input_line(); @@ -260,16 +286,24 @@ exit(1); } if (nfields < 2) { - fprintf(stderr, "%s line %d: osc-set must be non-empty\n", +emptyerr: fprintf(stderr, "%s line %d: osc-set must be non-empty\n", infname, lineno); exit(1); } - for (p = 1; p < nfields; p++) { + p = 1; + if (fields[p][0] == '(') { + dummy_time_byte = input_paren_number(fields[p], 0, 255); + p++; + if (nfields < 3) + goto emptyerr; + } else + dummy_time_byte = 0; + for (; p < nfields; p++) { oscn = input_number(fields[p], 0, 7); osc_bit = 1 << oscn; global_osc_set |= osc_bit; } - putc(0, outf); + putc(dummy_time_byte, outf); putc(global_osc_set, outf); }