mirror of
https://github.com/vishapoberon/oberonbyexample.git
synced 2026-04-05 21:02:25 +00:00
unix style command line arguments by calling traditional oberon
functions; -- noch
This commit is contained in:
commit
734202143e
1 changed files with 63 additions and 0 deletions
63
arguments/unixstyle_oberon_traditional/partest.Mod
Normal file
63
arguments/unixstyle_oberon_traditional/partest.Mod
Normal file
|
|
@ -0,0 +1,63 @@
|
||||||
|
MODULE partest;
|
||||||
|
|
||||||
|
IMPORT Oberon, Texts;
|
||||||
|
|
||||||
|
CONST
|
||||||
|
argStr0 = "str"; (* we only have two types of args, one string and one int *)
|
||||||
|
argInt0 = "int"; (* i. e. -str somestring -int somenumber *)
|
||||||
|
|
||||||
|
VAR
|
||||||
|
W: Texts.Writer; (* for console output *)
|
||||||
|
S: Texts.Scanner; T: Texts.Text;
|
||||||
|
BEGIN
|
||||||
|
Texts.OpenWriter(W);
|
||||||
|
Texts.WriteString(W, "hello, world, let's see which arguments do we get"); Texts.WriteLn(W);
|
||||||
|
|
||||||
|
(* open arguments scanner *)
|
||||||
|
Texts.OpenScanner(S, Oberon.Par.text, Oberon.Par.pos);
|
||||||
|
|
||||||
|
WHILE ~S.eot DO
|
||||||
|
Texts.Scan(S);
|
||||||
|
|
||||||
|
IF S.class = Texts.Char THEN (* do we get '-' sign ? *)
|
||||||
|
IF S.c = "-" THEN
|
||||||
|
Texts.Scan(S);
|
||||||
|
IF S.class = Texts.Name THEN (* we got the key *)
|
||||||
|
Texts.WriteString(W, "key: "); Texts.WriteString(W, S.s); Texts.WriteLn(W);
|
||||||
|
(* now get the value *)
|
||||||
|
IF S.s = argStr0 THEN
|
||||||
|
Texts.Scan(S);
|
||||||
|
IF S.class = Texts.Name THEN
|
||||||
|
Texts.WriteString(W, "value: "); Texts.WriteString (W, S.s); Texts.WriteLn(W); Texts.Append(Oberon.Log, W.buf);
|
||||||
|
ELSE
|
||||||
|
Texts.WriteString(W, "string expected"); Texts.WriteLn(W);
|
||||||
|
Texts.Append(Oberon.Log, W.buf);
|
||||||
|
HALT(1);
|
||||||
|
END;
|
||||||
|
ELSIF S.s = argInt0 THEN
|
||||||
|
Texts.Scan(S);
|
||||||
|
IF S.class = Texts.Int THEN
|
||||||
|
Texts.WriteString(W, "value: "); Texts.WriteInt (W, S.i, 0); Texts.WriteLn(W); Texts.Append(Oberon.Log, W.buf);
|
||||||
|
ELSE
|
||||||
|
Texts.WriteString(W, "integer expected"); Texts.WriteLn(W);
|
||||||
|
Texts.Append(Oberon.Log, W.buf);
|
||||||
|
HALT(1);
|
||||||
|
END;
|
||||||
|
END;
|
||||||
|
ELSE
|
||||||
|
(* we were expecting characters after the '-' sign *)
|
||||||
|
Texts.WriteString(W, "key name expected"); Texts. WriteLn(W);
|
||||||
|
Texts.Append(Oberon.Log, W.buf);
|
||||||
|
HALT(1);
|
||||||
|
END;
|
||||||
|
END
|
||||||
|
ELSE
|
||||||
|
Texts.WriteString(W, "key option must start with '-' sign "); Texts.WriteLn(W);
|
||||||
|
HALT(1);
|
||||||
|
END; (* if got '-' *)
|
||||||
|
Oberon.Par.pos := Texts.Pos(S);
|
||||||
|
Texts.Append(Oberon.Log, W.buf)
|
||||||
|
END; (* while *)
|
||||||
|
|
||||||
|
|
||||||
|
END partest.
|
||||||
Loading…
Add table
Add a link
Reference in a new issue