diff options
-rw-r--r-- | listamsb.1 | 93 | ||||
-rw-r--r-- | listamsb.c | 29 | ||||
-rw-r--r-- | listamsb.rst | 91 |
3 files changed, 138 insertions, 75 deletions
@@ -27,12 +27,12 @@ level margin: \\n[rst2man-indent\\n[rst2man-indent-level]] .\" new: \\n[rst2man-indent\\n[rst2man-indent-level]] .in \\n[rst2man-indent\\n[rst2man-indent-level]]u .. -.TH "LISTAMSB" 1 "2025-03-08" "0.2.1" "Urchlay's Atari 8-bit Tools" +.TH "LISTAMSB" 1 "2025-03-11" "0.2.1" "Urchlay's Atari 8-bit Tools" .SH NAME listamsb \- List the source of a tokenized Atari Microsoft BASIC program .SH SYNOPSIS .sp -listamsb [\fB\-l\fP] | [\fB\-C\fP] | [\fB\-D\fP] | [[\fB\-a\fP] [\fB\-c\fP] [\fB\-v\fP] [\fB\-h\fP] [\fB\-i\fP] [\fB\-u\fP] [\fB\-t\fP] [\fB\-m\fP] [\fB\-n\fP] [\fB\-s\fP] ...] [\fB\-r\fP \fIline\-range\fP] [\fBinput\-file\fP] [\fBoutput\-file\fP] +listamsb [\fB\-U\fP] | [\fB\-C\fP] | [\fB\-D\fP] | [[\fB\-L\fP] [\fB\-a\fP] [\fB\-c\fP] [\fB\-v\fP] [\fB\-h\fP] [\fB\-i\fP] [\fB\-u\fP] [\fB\-t\fP] [\fB\-m\fP] [\fB\-n\fP] [\fB\-s\fP] [\fB\-r\fP \fIline\-range\fP] ...] [\fBinput\-file\fP] [\fBoutput\-file\fP] .SH DESCRIPTION .sp \fBlistamsb\fP acts like the \fILIST\fP command in Atari Microsoft BASIC. It reads a @@ -52,45 +52,71 @@ input is read from \fBstdin\fP\&. .sp Programs created with \fISAVE "filename" LOCK\fP are autodetected, and will be listed normally. It\(aqs also possible to convert a LOCKed -program to an unencrypted one, with the \fB\-l\fP option. +program to an unencrypted one, with the \fB\-U\fP option. .sp Programs can be "crunched" and "decrunched" with the \fB\-C\fP and \fB\-D\fP options. .sp If no \fBoutput\-file\fP is given, output is to \fBstdout\fP\&. .SH OPTIONS +.SS Operation Modes .INDENT 0.0 .TP -.B \fB\-a\fP -Output raw ATASCII. This option must be used with an -\fBoutput\-file\fP, a pipe, or redirection: \fBlistamsb\fP will not write -ATASCII to a terminal. \fBa8cat\fP is not used, with this option. -.TP -.B \fB\-c\fP -Check only. No output on stdout. Diagnostics are still printed on stderr, -and the exit status is unchanged. It\(aqs an error to give an \fBoutput\-file\fP with -this option. +.B \fB\-L\fP +LIST program. This is the default, so there\(aqs no need to give this option +normally. See next section for options that control the listing. .TP .B \fB\-C\fP "Crunch" program: remove comments and spaces that occur outside of a -string. The resulting program is usually 5 to 10 percent smaller, and -will RUN correctly, but will be difficult to edit in AMSB because its -parser requires the spaces. Also, if any comment\-only lines are the -target of GOTO or GOSUB, the program won\(aqt run because all comment\-only -lines are removed. +string. The resulting program is tokenized, and is usually 5 to 10 +percent smaller. It should RUN correctly, but will be difficult to +edit in AMSB because its parser requires the spaces. +.sp +If any comment\-only lines are the target of GOTO or GOSUB, the +program won\(aqt RUN correctly because all comment\-only lines are +removed. If this happens, you can use the \fB\-k\fP option (see below). .sp This option must be used with an \fBoutput\-file\fP, since seeking is done. None of the other options have any effect with \fB\-C\fP\&. .TP .B \fB\-D\fP "Decrunch" a crunched program. Puts spaces where they\(aqre required for -AMSB\(aqs parser. The result will be editable in AMSB. Of course, any -comments that were removed during crunching will not magically be -retored (they\(aqre gone). +AMSB\(aqs parser. The resulting program is tokenized, and will be +editable in AMSB. Of course, any comments that were removed during +crunching will not magically be retored (they\(aqre gone). .sp This option must be used with an \fBoutput\-file\fP, since seeking is done. None of the other options have any effect with \fB\-D\fP\&. .TP +.B \fB\-U\fP +UnLOCK or LOCK the the program. Locked programs are created with +\fISAVE "filename" LOCK\fP\&. The "encryption" is a reciprocal cipher: locking and +unlocking are the same operation (similar to ROT13). The output will +be the locked or unlocked tokenized program (rather than a listing). +.sp +This option must be used with an \fBoutput\-file\fP, a pipe, or +redirection: \fBlistamsb\fP will not write tokenized BASIC to a +terminal. None of the other options have any effect with \fB\-U\fP\&. +.UNINDENT +.SS Options for \fB\-L\fP (list) Mode +.sp +None of these options have any effect when used with \fB\-C\fP, \fB\-D\fP, +or \fB\-U\fP\&. +.INDENT 0.0 +.TP +.B \fB\-a\fP +Output raw ATASCII. This option must be used with an +\fBoutput\-file\fP, a pipe, or redirection: \fBlistamsb\fP will not write +ATASCII to a terminal. \fBa8cat\fP is not used, with this option. +.TP +.B \fB\-c\fP +Check only. No output on stdout. Diagnostics are still printed on stderr, +and the exit status is unchanged. It\(aqs an error to give an \fBoutput\-file\fP with +this option. +.TP +.B \fB\-i\fP, \fB\-u\fP, \fB\-t\fP, \fB\-m\fP, \fB\-s\fP +These options are passed to \fBa8cat\fP\&. See its man page for details. +.TP .B \fB\-r\fP \fIline\-range\fP Show only part of the listing. \fIline\-range\fP can be a single line, or a comma\- or hyphen\-separated pair of starting and ending line numbers (e.g. \fB100,200\fP, or @@ -101,20 +127,21 @@ If the start line number is omitted (e.g. \fB,100\fP), it will be treated as number is omitted (e.g. \fB100,\fP), it means "list until the end of the program". \fB\-r,\fP or \fB\-r\-\fP is equivalent to not using the \fB\-r\fP option at all. .TP -.B \fB\-l\fP -"Lock" or "unlock" the program. Locked programs are created with -\fISAVE "filename" LOCK\fP\&. The "encryption" is a reciprocal cipher: locking and -unlocking are the same operation (similar to ROT13). The output will -be the locked or unlocked tokenized program (rather than a listing). -.sp -This option must be used with an \fBoutput\-file\fP, a pipe, or -redirection: \fBlistamsb\fP will not write tokenized BASIC to a -terminal. \fBa8cat\fP is not used, with this option. None of the -other options have any effect with \fB\-l\fP\&. -.TP .B \fB\-n\fP No empty line. By default, \fBlistamsb\fP prints an empty line at the start of the output, to match AMSB\(aqs LIST command. +.UNINDENT +.SS Options for \fB\-C\fP (crunch) Mode +.INDENT 0.0 +.TP +.B \fB\-k\fP +Keep comment\-only lines. Normally these are removed. If the program +gives UNDEF\(aqD LINE ERROR, it means the target line was a comment\-only +line that got removed. With \fB\-k\fP, these lines will be kept, although +the actual comments won\(aqt (\fI10 REM HELLO\fP will become \fI10 REM\fP). +.UNINDENT +.SS Utility Options +.INDENT 0.0 .TP .B \fB\-v\fP Verbose output, on \fBstderr\fP\&. May be given twice for extra verbosity, @@ -125,10 +152,6 @@ Print built\-in help and exit. .TP .B \fB\-\-version\fP Print version number and exit. -.TP -.B \fB\-i\fP, \fB\-u\fP, \fB\-t\fP, \fB\-m\fP, \fB\-s\fP -These options are passed to \fBa8cat\fP\&. See its man page for details. If -any of the \fB\-a\fP, \fB\-c\fP, or \fB\-l\fP options are used, these options have no effect. .UNINDENT .SH DIAGNOSTICS .sp @@ -90,6 +90,7 @@ int unlock_mode = 0; /* -l */ int initial_eol = 1; /* -n */ int crunch = 0; /* -C, -D */ int decrunch = 0; /* -D */ +int keep_rems = 0; /* -k */ int locked = 0; int need_pclose = 0; @@ -528,16 +529,27 @@ int crunch_line(void) { } /* omit comment-only lines */ - if(code[0] == TOK_REM) return 0; - if(code[0] == ':') { - if(code[1] == TOK_SQUOTE || code[1] == TOK_BANG) - return 0; + if(!keep_rems) { + if(code[0] == TOK_REM) return 0; + if(code[0] == ':') { + if(code[1] == TOK_SQUOTE || code[1] == TOK_BANG) + return 0; + } } /* omit trailing comments */ - if(commentstart) { + if(commentstart > 1) { code[commentstart - 1] = 0; /* null out the colon before the comment */ codelen = commentstart; + + /* removing the comment from this: 10 PRINT :! BLAH + ...leaves a trailing colon. get rid of it if needed. */ + if(codelen >= 2) { + if(code[codelen - 2] == ':') { + code[codelen - 2] = 0; + codelen--; + } + } } codelen += 4; /* account for ptr and lineno */ @@ -832,11 +844,14 @@ void parse_args(int argc, char **argv) { } } - while( (opt = getopt(argc, argv, "DCnlr:cvaiutmsh")) != -1) { + while( (opt = getopt(argc, argv, "DCnLUlr:cvaiutmshk")) != -1) { switch(opt) { + case 'L': crunch = decrunch = 0; break; case 'D': crunch = decrunch = 1; break; case 'C': crunch = 1; break; - case 'l': unlock_mode = 1; break; + case 'l': + case 'U': unlock_mode = 1; break; + case 'k': keep_rems = 1; break; case 'c': check_only = 1; break; case 'a': raw_output = 1; break; case 'v': verbosity++ ; break; diff --git a/listamsb.rst b/listamsb.rst index 902319b..dac3c1e 100644 --- a/listamsb.rst +++ b/listamsb.rst @@ -11,7 +11,7 @@ List the source of a tokenized Atari Microsoft BASIC program SYNOPSIS ======== -listamsb [**-l**] | [**-C**] | [**-D**] | [[**-a**\] [**-c**] [**-v**\] [**-h**\] [**-i**\] [**-u**\] [**-t**\] [**-m**\] [**-n**\] [**-s**\] ...] [**-r** *line-range*] [**input-file**\] [**output-file**\] +listamsb [**-U**] | [**-C**] | [**-D**] | [[**-L**] [**-a**] [**-c**] [**-v**] [**-h**] [**-i**] [**-u**] [**-t**] [**-m**] [**-n**] [**-s**] [**-r** *line-range*] ...] [**input-file**] [**output-file**] DESCRIPTION =========== @@ -33,7 +33,7 @@ input is read from **stdin**. Programs created with *SAVE "filename" LOCK* are autodetected, and will be listed normally. It's also possible to convert a LOCKed -program to an unencrypted one, with the **-l** option. +program to an unencrypted one, with the **-U** option. Programs can be "crunched" and "decrunched" with the **-C** and **-D** options. @@ -43,36 +43,64 @@ If no **output-file** is given, output is to **stdout**. OPTIONS ======= -**-a** - Output raw ATASCII. This option must be used with an - **output-file**, a pipe, or redirection: **listamsb** will not write - ATASCII to a terminal. **a8cat** is not used, with this option. +Operation Modes +--------------- -**-c** - Check only. No output on stdout. Diagnostics are still printed on stderr, - and the exit status is unchanged. It's an error to give an **output-file** with - this option. +**-L** + LIST program. This is the default, so there's no need to give this option + normally. See next section for options that control the listing. **-C** "Crunch" program: remove comments and spaces that occur outside of a - string. The resulting program is usually 5 to 10 percent smaller, and - will RUN correctly, but will be difficult to edit in AMSB because its - parser requires the spaces. Also, if any comment-only lines are the - target of GOTO or GOSUB, the program won't run because all comment-only - lines are removed. + string. The resulting program is tokenized, and is usually 5 to 10 + percent smaller. It should RUN correctly, but will be difficult to + edit in AMSB because its parser requires the spaces. + + If any comment-only lines are the target of GOTO or GOSUB, the + program won't RUN correctly because all comment-only lines are + removed. If this happens, you can use the **-k** option (see below). This option must be used with an **output-file**, since seeking is done. None of the other options have any effect with **-C**. **-D** "Decrunch" a crunched program. Puts spaces where they're required for - AMSB's parser. The result will be editable in AMSB. Of course, any - comments that were removed during crunching will not magically be - retored (they're gone). + AMSB's parser. The resulting program is tokenized, and will be + editable in AMSB. Of course, any comments that were removed during + crunching will not magically be retored (they're gone). This option must be used with an **output-file**, since seeking is done. None of the other options have any effect with **-D**. +**-U** + UnLOCK or LOCK the the program. Locked programs are created with + *SAVE "filename" LOCK*. The "encryption" is a reciprocal cipher: locking and + unlocking are the same operation (similar to ROT13). The output will + be the locked or unlocked tokenized program (rather than a listing). + + This option must be used with an **output-file**, a pipe, or + redirection: **listamsb** will not write tokenized BASIC to a + terminal. None of the other options have any effect with **-U**. + +Options for **-L** (list) Mode +------------------------------ + +None of these options have any effect when used with **-C**, **-D**, +or **-U**. + +**-a** + Output raw ATASCII. This option must be used with an + **output-file**, a pipe, or redirection: **listamsb** will not write + ATASCII to a terminal. **a8cat** is not used, with this option. + +**-c** + Check only. No output on stdout. Diagnostics are still printed on stderr, + and the exit status is unchanged. It's an error to give an **output-file** with + this option. + +**-i**\, **-u**\, **-t**\, **-m**\, **-s** + These options are passed to **a8cat**. See its man page for details. + **-r** *line-range* Show only part of the listing. *line-range* can be a single line, or a comma- or hyphen-separated pair of starting and ending line numbers (e.g. **100,200**, or @@ -83,21 +111,22 @@ OPTIONS number is omitted (e.g. **100,**), it means "list until the end of the program". **-r,** or **-r-** is equivalent to not using the **-r** option at all. -**-l** - "Lock" or "unlock" the program. Locked programs are created with - *SAVE "filename" LOCK*. The "encryption" is a reciprocal cipher: locking and - unlocking are the same operation (similar to ROT13). The output will - be the locked or unlocked tokenized program (rather than a listing). - - This option must be used with an **output-file**, a pipe, or - redirection: **listamsb** will not write tokenized BASIC to a - terminal. **a8cat** is not used, with this option. None of the - other options have any effect with **-l**. - **-n** No empty line. By default, **listamsb** prints an empty line at the start of the output, to match AMSB's LIST command. +Options for **-C** (crunch) Mode +-------------------------------- + +**-k** + Keep comment-only lines. Normally these are removed. If the program + gives UNDEF'D LINE ERROR, it means the target line was a comment-only + line that got removed. With **-k**, these lines will be kept, although + the actual comments won't (*10 REM HELLO* will become *10 REM*). + +Utility Options +--------------- + **-v** Verbose output, on **stderr**. May be given twice for extra verbosity, which shows each line number, its offset, length, and end-of-line pointer. @@ -108,10 +137,6 @@ OPTIONS **--version** Print version number and exit. -**-i**\, **-u**\, **-t**\, **-m**\, **-s** - These options are passed to **a8cat**. See its man page for details. If - any of the **-a**, **-c**, or **-l** options are used, these options have no effect. - DIAGNOSTICS =========== |