diff options
Diffstat (limited to 'games')
-rw-r--r-- | games/morse/morse.6 | 5 | ||||
-rw-r--r-- | games/morse/morse.c | 45 |
2 files changed, 33 insertions, 17 deletions
diff --git a/games/morse/morse.6 b/games/morse/morse.6 index 1e3b68b..21be6c9 100644 --- a/games/morse/morse.6 +++ b/games/morse/morse.6 @@ -46,6 +46,7 @@ .Op Fl e .Op Fl w Ar speed .Op Fl f Ar frequency +.Op Fl l .Op Fl s .Op Ar string ... .Sh DESCRIPTION @@ -56,6 +57,10 @@ Acceptable input are command line arguments or the standard input. .Pp Available options: .Bl -tag -width flag +.It Fl l +The +.Fl l +option produces output suitable for led(4) devices. .It Fl s The .Fl s diff --git a/games/morse/morse.c b/games/morse/morse.c index 832228d..3b7a404 100644 --- a/games/morse/morse.c +++ b/games/morse/morse.c @@ -202,11 +202,11 @@ void show(const char *), play(const char *), morse(char); void ttyout(const char *); void sighandler(int); -#define GETOPTOPTS "d:ef:sw:" +#define GETOPTOPTS "d:ef:lsw:" #define USAGE \ -"usage: morse [-s] [-e] [-d device] [-w speed] [-f frequency] [string ...]\n" +"usage: morse [-els] [-d device] [-w speed] [-f frequency] [string ...]\n" -static int pflag, sflag, eflag; +static int pflag, lflag, sflag, eflag; static int wpm = 20; /* words per minute */ #define FREQUENCY 600 static int freq = FREQUENCY; @@ -223,7 +223,7 @@ int olflags; #ifdef SPEAKER tone_t sound; #undef GETOPTOPTS -#define GETOPTOPTS "d:ef:psw:" +#define GETOPTOPTS "d:ef:lpsw:" #undef USAGE #define USAGE \ "usage: morse [-s] [-p] [-e] [-d device] [-w speed] [-f frequency] [string ...]\n" @@ -249,6 +249,9 @@ main(int argc, char **argv) case 'f': freq = atoi(optarg); break; + case 'l': + lflag = 1; + break; #ifdef SPEAKER case 'p': pflag = 1; @@ -265,8 +268,12 @@ main(int argc, char **argv) fputs(USAGE, stderr); exit(1); } - if ((pflag || device) && sflag) { - fputs("morse: only one of -p, -d and -s allowed\n", stderr); + if (sflag && lflag) { + fputs("morse: only one of -l and -s allowed\n", stderr); + exit(1); + } + if ((pflag || device) && (sflag || lflag)) { + fputs("morse: only one of -p, -d and -l, -s allowed\n", stderr); exit(1); } if ((pflag || device) && ((wpm < 1) || (wpm > 60))) { @@ -328,6 +335,8 @@ main(int argc, char **argv) hightab = iso8859tab; } + if (lflag) + printf("m"); if (*argv) { do { for (p = *argv; *p; ++p) { @@ -361,16 +370,15 @@ morse(char c) if ((c == '\r') || (c == '\n')) c = ' '; if (c == ' ') { - if (pflag) { + if (pflag) play(" "); - return; - } else if (device) { + else if (device) ttyout(" "); - return; - } else { + else if (lflag) + printf("\n"); + else show(""); - return; - } + return; } for (m = ((unsigned char)c < 0x80? mtab: hightab); m != NULL && m->inchar != '\0'; @@ -389,12 +397,15 @@ morse(char c) void show(const char *s) { - if (sflag) - printf(" %s", s); - else + if (lflag) { + printf("%s ", s); + } else if (sflag) { + printf(" %s\n", s); + } else { for (; *s; ++s) printf(" %s", *s == '.' ? "dit" : "dah"); - printf("\n"); + printf("\n"); + } } void |