diff options
author | Freya Murphy <freya@freyacat.org> | 2025-03-25 17:36:52 -0400 |
---|---|---|
committer | Freya Murphy <freya@freyacat.org> | 2025-03-25 17:38:22 -0400 |
commit | 6af21e6a4f2251e71353562d5df7f376fdffc270 (patch) | |
tree | de20c7afc9878422c81e34f30c6b010075e9e69a /user/progDE.c | |
download | comus-6af21e6a4f2251e71353562d5df7f376fdffc270.tar.gz comus-6af21e6a4f2251e71353562d5df7f376fdffc270.tar.bz2 comus-6af21e6a4f2251e71353562d5df7f376fdffc270.zip |
initial checkout from wrc
Diffstat (limited to 'user/progDE.c')
-rw-r--r-- | user/progDE.c | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/user/progDE.c b/user/progDE.c new file mode 100644 index 0000000..a1aa0b3 --- /dev/null +++ b/user/progDE.c @@ -0,0 +1,56 @@ +#include <common.h> + +/** +** User function main #2: write +** +** Prints its ID, then loops N times delaying and printing, then returns +** without calling exit(). Verifies the return byte count from each call +** to write(). +** +** Invoked as: main2 x n +** where x is the ID character +** n is the iteration count +*/ + +USERMAIN( main ) { + int n; + int count = 30; // default iteration count + char ch = '2'; // default character to print + char buf[128]; + + // process the command-line arguments + switch( argc ) { + case 3: count = str2int( argv[2], 10 ); + // FALL THROUGH + case 2: ch = argv[1][0]; + break; + default: + sprint( buf, "main2: argc %d, args: ", argc ); + cwrites( buf ); + for( int i = 0; i <= argc; ++i ) { + sprint( buf, " %s", argv[argc] ? argv[argc] : "(null)" ); + cwrites( buf ); + } + cwrites( "\n" ); + } + + // announce our presence + n = swritech( ch ); + if( n != 1 ) { + sprint( buf, "== %c, write #1 returned %d\n", ch, n ); + cwrites( buf ); + } + + // iterate and print the required number of other characters + for( int i = 0; i < count; ++i ) { + DELAY(STD); + n = swritech( ch ); + if( n != 1 ) { + sprint( buf, "== %c, write #2 returned %d\n", ch, n ); + cwrites( buf ); + } + } + + // all done! + return( 0 ); +} |