Control.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. namespace NTERA.Interpreter
  2. {
  3. public partial class Interpreter
  4. {
  5. private void If()
  6. {
  7. bool result = Expr().BinOp(new Value(0), Token.Equal).Real == 1;
  8. Match(Token.Then);
  9. GetNextToken();
  10. if (result)
  11. {
  12. int i = ifcounter;
  13. while (true)
  14. {
  15. if (lastToken == Token.If)
  16. {
  17. i++;
  18. }
  19. else if (lastToken == Token.Else)
  20. {
  21. if (i == ifcounter)
  22. {
  23. GetNextToken();
  24. return;
  25. }
  26. }
  27. else if (lastToken == Token.EndIf)
  28. {
  29. if(i == ifcounter)
  30. {
  31. GetNextToken();
  32. return;
  33. }
  34. i--;
  35. }
  36. GetNextToken();
  37. }
  38. }
  39. }
  40. private void Else()
  41. {
  42. int i = ifcounter;
  43. while (true)
  44. {
  45. if (lastToken == Token.If)
  46. {
  47. i++;
  48. }
  49. else if (lastToken == Token.EndIf)
  50. {
  51. if(i == ifcounter)
  52. {
  53. GetNextToken();
  54. return;
  55. }
  56. i--;
  57. }
  58. GetNextToken ();
  59. }
  60. }
  61. private void End()
  62. {
  63. exit = true;
  64. }
  65. private void Let()
  66. {
  67. if (lastToken != Token.Equal)
  68. {
  69. Match(Token.Identifer);
  70. GetNextToken();
  71. Match(Token.Equal);
  72. }
  73. string id = lex.Identifer;
  74. GetNextToken();
  75. SetVar(id, Expr());
  76. }
  77. private void For()
  78. {
  79. Match(Token.Identifer);
  80. string var = lex.Identifer;
  81. GetNextToken();
  82. Match(Token.Equal);
  83. GetNextToken();
  84. Value v = Expr();
  85. if (loops.ContainsKey(var))
  86. {
  87. loops[var] = lineMarker;
  88. }
  89. else
  90. {
  91. SetVar(var, v);
  92. loops.Add(var, lineMarker);
  93. }
  94. Match(Token.To);
  95. GetNextToken();
  96. v = Expr();
  97. if (vars[var].BinOp(v, Token.More).Real == 1)
  98. {
  99. while (true)
  100. {
  101. while (!(GetNextToken() == Token.Identifer && prevToken == Token.Next)) ;
  102. if (lex.Identifer == var)
  103. {
  104. loops.Remove(var);
  105. GetNextToken();
  106. Match(Token.NewLine);
  107. break;
  108. }
  109. }
  110. }
  111. }
  112. private void Next()
  113. {
  114. Match(Token.Identifer);
  115. string var = lex.Identifer;
  116. vars[var] = vars[var].BinOp(new Value(1), Token.Plus);
  117. lex.GoTo(new Marker(loops[var].Pointer - 1, loops[var].Line, loops[var].Column - 1));
  118. lastToken = Token.NewLine;
  119. }
  120. }
  121. }