diff --git a/src/test.c b/src/test.c
index 9fad93d4461223fcc752d5a79e48261711e9709d..d2501611eee396c8c7f2e4036d115937e967eec3 100644 (file)
--- a/src/test.c
+++ b/src/test.c
#include "../include/oberon.h"
+/*
static char source_test[] =
"(* Main module *)"
"MODULE Test;"
"IMPORT Out;"
""
- "VAR"
- " byte : BYTE;"
- " short : SHORTINT;"
- " int : INTEGER;"
- " long : LONGINT;"
- " real : REAL;"
- " longreal : LONGREAL;"
+ "TYPE"
+ " R = LONGINT;"
""
+ "PROCEDURE Factorial(n : R) : R;"
"BEGIN"
- " Out.Open;"
- " byte := 127;"
- " int := 666 DIV 2;"
- " long := int;"
- " real := (4 / 1) - (4 / 3) + (4 / 5) - (4 / 7) + (4 / 9) - (4 / 11) + (4 / 13) - (4 / 15) + (4 / 17);"
- " longreal := (4 / 1) - (4 / 3) + (4 / 5) - (4 / 7) + (4 / 9) - (4 / 11) + (4 / 13) - (4 / 15) + (4 / 17);"
- " Out.Int(666, 0); Out.Ln;"
- " Out.Int(byte, 0); Out.Ln;"
- " Out.Real(real, 0); Out.Ln;"
- " Out.LongReal(longreal, 0); Out.Ln;"
+ " IF n <= 1 THEN"
+ " RETURN 1;"
+ " ELSE"
+ " RETURN n * Factorial(n - 1);"
+ " END;"
+ " RETURN 0; (* Детектор ретурнов - дерьмо *)"
+ "END Factorial;"
+ ""
+ "BEGIN"
+ " Out.Open();"
+ " Out.Int(Factorial(0), 0); Out.Ln;"
+ " Out.Int(Factorial(1), 0); Out.Ln;"
+ " Out.Int(Factorial(2), 0); Out.Ln;"
+ " Out.Int(Factorial(3), 0); Out.Ln;"
+ " Out.Int(Factorial(4), 0); Out.Ln;"
+ " Out.Int(Factorial(5), 0); Out.Ln;"
+ " Out.Int(Factorial(6), 0); Out.Ln;"
+ " Out.Int(Factorial(7), 0); Out.Ln;"
+ " Out.Int(Factorial(8), 0); Out.Ln;"
+ " Out.Int(Factorial(9), 0); Out.Ln;"
+ " Out.Int(Factorial(10), 0); Out.Ln;"
+ " Out.Int(Factorial(11), 0); Out.Ln;"
+ " Out.Int(Factorial(12), 0); Out.Ln;"
+ " Out.Int(Factorial(13), 0); Out.Ln;"
+ " Out.Int(Factorial(14), 0); Out.Ln;"
+ " Out.Int(Factorial(15), 0); Out.Ln;"
+ " Out.Int(Factorial(16), 0); Out.Ln;"
+ " Out.Int(Factorial(17), 0); Out.Ln;"
+ " Out.Int(Factorial(18), 0); Out.Ln;"
+ " Out.Int(Factorial(19), 0); Out.Ln;"
+ " Out.Int(Factorial(20), 0); Out.Ln;"
"END Test."
;
+*/
-// PROCEDURE Char* (ch : CHAR);
-// PROCEDURE String* (str : ARRAY OF CHAR);
+static char source_test[] =
+ "(* Main module *)"
+ "MODULE Test;"
+ "IMPORT Out;"
+ ""
+ "TYPE"
+ " R = LONGREAL;"
+ ""
+ "PROCEDURE Factorial(n : R) : R;"
+ "BEGIN"
+ " IF n <= 1 THEN"
+ " RETURN 1;"
+ " ELSE"
+ " RETURN n * Factorial(n - 1);"
+ " END;"
+ " RETURN 0; (* Детектор ретурнов - дерьмо *)"
+ "END Factorial;"
+ ""
+ "BEGIN"
+ " Out.Open();"
+ " Out.LongReal(Factorial(0), 0); Out.Ln;"
+ " Out.LongReal(Factorial(1), 0); Out.Ln;"
+ " Out.LongReal(Factorial(2), 0); Out.Ln;"
+ " Out.LongReal(Factorial(3), 0); Out.Ln;"
+ " Out.LongReal(Factorial(4), 0); Out.Ln;"
+ " Out.LongReal(Factorial(5), 0); Out.Ln;"
+ " Out.LongReal(Factorial(6), 0); Out.Ln;"
+ " Out.LongReal(Factorial(7), 0); Out.Ln;"
+ " Out.LongReal(Factorial(8), 0); Out.Ln;"
+ " Out.LongReal(Factorial(9), 0); Out.Ln;"
+ " Out.LongReal(Factorial(10), 0); Out.Ln;"
+ " Out.LongReal(Factorial(11), 0); Out.Ln;"
+ " Out.LongReal(Factorial(12), 0); Out.Ln;"
+ " Out.LongReal(Factorial(13), 0); Out.Ln;"
+ " Out.LongReal(Factorial(14), 0); Out.Ln;"
+ " Out.LongReal(Factorial(15), 0); Out.Ln;"
+ " Out.LongReal(Factorial(16), 0); Out.Ln;"
+ " Out.LongReal(Factorial(17), 0); Out.Ln;"
+ " Out.LongReal(Factorial(18), 0); Out.Ln;"
+ " Out.LongReal(Factorial(19), 0); Out.Ln;"
+ " Out.LongReal(Factorial(20), 0); Out.Ln;"
+ " Out.LongReal(Factorial(170), 0); Out.Ln;"
+ "END Test."
+;
static char source_out[] =
"MODULE Out;"
" PROCEDURE Open*;"
" END Open;"
""
+ " PROCEDURE Char* (ch : CHAR);"
+ " END Char;"
+ ""
+ " PROCEDURE String* (str : ARRAY OF CHAR);"
+ " END String;"
+ ""
" PROCEDURE Int*(i, n : LONGINT);"
" END Int;"
""