DEADSOFTWARE

JVM: Исправлено сравнение LongInt, Real и LongReal
[dsw-obn.git] / src / test.c
index 9fad93d4461223fcc752d5a79e48261711e9709d..d2501611eee396c8c7f2e4036d115937e967eec3 100644 (file)
 
 #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;"
        ""