|  | @@ -1,3 +1,8 @@
 | 
												
													
														
															|  | 
 |  | +// iVProg - www.usp.br/line/ivprog
 | 
												
													
														
															|  | 
 |  | +// LInE - Free Education, Private Data
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +// This is used when is loaded "ivph" file (under the button "upload" or GET)
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  import { IVProgParser } from "../ast/ivprogParser";
 |  |  import { IVProgParser } from "../ast/ivprogParser";
 | 
												
													
														
															|  |  import * as Expressions from "../ast/expressions";
 |  |  import * as Expressions from "../ast/expressions";
 | 
												
													
														
															|  |  import { Types } from "../typeSystem/types";
 |  |  import { Types } from "../typeSystem/types";
 | 
												
											
												
													
														
															|  | @@ -13,7 +18,7 @@ const TYPES = {
 | 
												
													
														
															|  |    RELATIONAL: "relational",
 |  |    RELATIONAL: "relational",
 | 
												
													
														
															|  |    LOGIC: "logic",
 |  |    LOGIC: "logic",
 | 
												
													
														
															|  |    ARITHMETIC: "arithmetic",
 |  |    ARITHMETIC: "arithmetic",
 | 
												
													
														
															|  | -};
 |  | 
 | 
												
													
														
															|  | 
 |  | +  };
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  function translateOp (type, op) {
 |  |  function translateOp (type, op) {
 | 
												
													
														
															|  |    switch (type) {
 |  |    switch (type) {
 | 
												
											
												
													
														
															|  | @@ -28,10 +33,10 @@ function translateOp (type, op) {
 | 
												
													
														
															|  |          return "or";
 |  |          return "or";
 | 
												
													
														
															|  |        } else {
 |  |        } else {
 | 
												
													
														
															|  |          return "not";
 |  |          return "not";
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  |        }
 |  |        }
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  |    }
 |  |    }
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  function getOpType (op) {
 |  |  function getOpType (op) {
 | 
												
													
														
															|  |    switch (op.ord) {
 |  |    switch (op.ord) {
 | 
												
											
												
													
														
															|  | @@ -50,24 +55,24 @@ function getOpType (op) {
 | 
												
													
														
															|  |        return TYPES.RELATIONAL;
 |  |        return TYPES.RELATIONAL;
 | 
												
													
														
															|  |      default:
 |  |      default:
 | 
												
													
														
															|  |        return TYPES.LOGIC;
 |  |        return TYPES.LOGIC;
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    }
 |  |    }
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.Case} switchCase
 |  |   * @param {Commands.Case} switchCase
 | 
												
													
														
															|  |   * */
 |  |   * */
 | 
												
													
														
															|  |  function switchCaseWalker (switchCase) {
 |  |  function switchCaseWalker (switchCase) {
 | 
												
													
														
															|  |    const commands = switchCase.commands.map(commandWalker);
 |  |    const commands = switchCase.commands.map(commandWalker);
 | 
												
													
														
															|  | -  const expression = switchCase.isDefault
 |  | 
 | 
												
													
														
															|  | -    ? null
 |  | 
 | 
												
													
														
															|  | -    : expressionWalker(switchCase.expression);
 |  | 
 | 
												
													
														
															|  | 
 |  | +  const expression = switchCase.isDefault ? null : expressionWalker(switchCase.expression);
 | 
												
													
														
															|  |    return {
 |  |    return {
 | 
												
													
														
															|  |      type: "switchcase",
 |  |      type: "switchcase",
 | 
												
													
														
															|  |      line: switchCase.sourceInfo.line,
 |  |      line: switchCase.sourceInfo.line,
 | 
												
													
														
															|  |      expression,
 |  |      expression,
 | 
												
													
														
															|  |      commands,
 |  |      commands,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.Switch} switchCommand
 |  |   * @param {Commands.Switch} switchCommand
 | 
												
											
												
													
														
															|  | @@ -79,8 +84,9 @@ function switchWalker (switchCommand) {
 | 
												
													
														
															|  |      type: "switch",
 |  |      type: "switch",
 | 
												
													
														
															|  |      expression,
 |  |      expression,
 | 
												
													
														
															|  |      cases,
 |  |      cases,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.Return} returnCommand
 |  |   * @param {Commands.Return} returnCommand
 | 
												
											
												
													
														
															|  | @@ -89,16 +95,18 @@ function returnWalker (returnCommand) {
 | 
												
													
														
															|  |    let expression = null;
 |  |    let expression = null;
 | 
												
													
														
															|  |    if (returnCommand.expression !== null) {
 |  |    if (returnCommand.expression !== null) {
 | 
												
													
														
															|  |      expression = expressionWalker(returnCommand.expression);
 |  |      expression = expressionWalker(returnCommand.expression);
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    return {
 |  |    return {
 | 
												
													
														
															|  |      type: "return",
 |  |      type: "return",
 | 
												
													
														
															|  |      expression,
 |  |      expression,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  function breakWalker (_) {
 |  |  function breakWalker (_) {
 | 
												
													
														
															|  |    return { type: "break" };
 |  |    return { type: "break" };
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.For} forLoop
 |  |   * @param {Commands.For} forLoop
 | 
												
											
												
													
														
															|  | @@ -107,9 +115,7 @@ function forWalker (forLoop) {
 | 
												
													
														
															|  |    const var_attribution = expressionWalker(forLoop.for_id);
 |  |    const var_attribution = expressionWalker(forLoop.for_id);
 | 
												
													
														
															|  |    const var_initial = expressionWalker(forLoop.for_from);
 |  |    const var_initial = expressionWalker(forLoop.for_from);
 | 
												
													
														
															|  |    const condition = expressionWalker(forLoop.for_to);
 |  |    const condition = expressionWalker(forLoop.for_to);
 | 
												
													
														
															|  | -  const step_expression = forLoop.for_pass
 |  | 
 | 
												
													
														
															|  | -    ? expressionWalker(forLoop.for_pass)
 |  | 
 | 
												
													
														
															|  | -    : [];
 |  | 
 | 
												
													
														
															|  | 
 |  | +  const step_expression = forLoop.for_pass ? expressionWalker(forLoop.for_pass) : [];
 | 
												
													
														
															|  |    const commands = forLoop.commands.map(commandWalker);
 |  |    const commands = forLoop.commands.map(commandWalker);
 | 
												
													
														
															|  |    return {
 |  |    return {
 | 
												
													
														
															|  |      type: "repeatNtimes",
 |  |      type: "repeatNtimes",
 | 
												
											
												
													
														
															|  | @@ -118,8 +124,8 @@ function forWalker (forLoop) {
 | 
												
													
														
															|  |      condition,
 |  |      condition,
 | 
												
													
														
															|  |      step_expression,
 |  |      step_expression,
 | 
												
													
														
															|  |      commands,
 |  |      commands,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.While} whileLoop
 |  |   * @param {Commands.While} whileLoop
 | 
												
											
												
													
														
															|  | @@ -132,8 +138,9 @@ function whileWalker (whileLoop) {
 | 
												
													
														
															|  |      type,
 |  |      type,
 | 
												
													
														
															|  |      expression,
 |  |      expression,
 | 
												
													
														
															|  |      commands,
 |  |      commands,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.IfThenElse} ifthenelse
 |  |   * @param {Commands.IfThenElse} ifthenelse
 | 
												
											
												
													
														
															|  | @@ -148,16 +155,17 @@ function ifThenElseWalker (ifthenelse) {
 | 
												
													
														
															|  |        ifFalse = ifthenelse.ifFalse.commands.map(commandWalker);
 |  |        ifFalse = ifthenelse.ifFalse.commands.map(commandWalker);
 | 
												
													
														
															|  |      } else {
 |  |      } else {
 | 
												
													
														
															|  |        ifFalse = [ifThenElseWalker(ifthenelse.ifFalse)];
 |  |        ifFalse = [ifThenElseWalker(ifthenelse.ifFalse)];
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  |    return {
 |  |    return {
 | 
												
													
														
															|  |      type: "iftrue",
 |  |      type: "iftrue",
 | 
												
													
														
															|  |      expression,
 |  |      expression,
 | 
												
													
														
															|  |      ifTrue,
 |  |      ifTrue,
 | 
												
													
														
															|  |      ifFalse,
 |  |      ifFalse,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  |  }
 |  |  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.Assign} assingment
 |  |   * @param {Commands.Assign} assingment
 | 
												
													
														
															|  |   * */
 |  |   * */
 | 
												
											
												
													
														
															|  | @@ -170,29 +178,27 @@ function assignmentWalker (assingment) {
 | 
												
													
														
															|  |      if (assingment.column) {
 |  |      if (assingment.column) {
 | 
												
													
														
															|  |        arrayClass = "matrix";
 |  |        arrayClass = "matrix";
 | 
												
													
														
															|  |        column = expressionWalker(assingment.column);
 |  |        column = expressionWalker(assingment.column);
 | 
												
													
														
															|  | -    }
 |  | 
 | 
												
													
														
															|  | -    variable = [
 |  | 
 | 
												
													
														
															|  | -      {
 |  | 
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  | 
 |  | +    variable = [ {
 | 
												
													
														
															|  |          instance: "expression",
 |  |          instance: "expression",
 | 
												
													
														
															|  |          type: TYPES.VARIABLE,
 |  |          type: TYPES.VARIABLE,
 | 
												
													
														
															|  |          class: arrayClass,
 |  |          class: arrayClass,
 | 
												
													
														
															|  |          column: column,
 |  |          column: column,
 | 
												
													
														
															|  |          line: line,
 |  |          line: line,
 | 
												
													
														
															|  |          value: assingment.id,
 |  |          value: assingment.id,
 | 
												
													
														
															|  | -      },
 |  | 
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | 
 |  | +        },
 | 
												
													
														
															|  | 
 |  | +      ];
 | 
												
													
														
															|  |    } else {
 |  |    } else {
 | 
												
													
														
															|  | -    variable = [
 |  | 
 | 
												
													
														
															|  | -      { instance: "expression", type: TYPES.VARIABLE, value: assingment.id },
 |  | 
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    variable = [ { instance: "expression", type: TYPES.VARIABLE, value: assingment.id }, ];
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    const expression = expressionWalker(assingment.expression);
 |  |    const expression = expressionWalker(assingment.expression);
 | 
												
													
														
															|  |    return {
 |  |    return {
 | 
												
													
														
															|  |      type: "attribution",
 |  |      type: "attribution",
 | 
												
													
														
															|  |      variable,
 |  |      variable,
 | 
												
													
														
															|  |      expression,
 |  |      expression,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Command} command
 |  |   * @param {Command} command
 | 
												
											
												
													
														
															|  | @@ -217,10 +223,11 @@ function commandWalker (command) {
 | 
												
													
														
															|  |      parsedCommand = forWalker(command);
 |  |      parsedCommand = forWalker(command);
 | 
												
													
														
															|  |    } else {
 |  |    } else {
 | 
												
													
														
															|  |      throw new Error("not implemented");
 |  |      throw new Error("not implemented");
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    parsedCommand.line = command.sourceInfo.line;
 |  |    parsedCommand.line = command.sourceInfo.line;
 | 
												
													
														
															|  |    return parsedCommand;
 |  |    return parsedCommand;
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.FunctionCall} functionCall
 |  |   * @param {Commands.FunctionCall} functionCall
 | 
												
											
												
													
														
															|  | @@ -229,33 +236,33 @@ function functionCallWalker (functionCall) {
 | 
												
													
														
															|  |    let name = functionCall.id;
 |  |    let name = functionCall.id;
 | 
												
													
														
															|  |    if (name.indexOf(".") !== -1) {
 |  |    if (name.indexOf(".") !== -1) {
 | 
												
													
														
															|  |      name = name.split(".")[1];
 |  |      name = name.split(".")[1];
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    const parameters = functionCall.actualParameters.map(expressionWalker);
 |  |    const parameters = functionCall.actualParameters.map(expressionWalker);
 | 
												
													
														
															|  |    if (name === "$write") {
 |  |    if (name === "$write") {
 | 
												
													
														
															|  |      const lastInput = parameters[parameters.length - 1][0];
 |  |      const lastInput = parameters[parameters.length - 1][0];
 | 
												
													
														
															|  |      // if lastInput is an object with value === '\n', newLine is true
 |  |      // if lastInput is an object with value === '\n', newLine is true
 | 
												
													
														
															|  |      const newLine = lastInput.value && lastInput.value.match(/^\n$/) !== null;
 |  |      const newLine = lastInput.value && lastInput.value.match(/^\n$/) !== null;
 | 
												
													
														
															|  | -    const content = newLine
 |  | 
 | 
												
													
														
															|  | -      ? parameters.slice(0, parameters.length - 1)
 |  | 
 | 
												
													
														
															|  | -      : parameters;
 |  | 
 | 
												
													
														
															|  | 
 |  | +    const content = newLine ? parameters.slice(0, parameters.length - 1) : parameters;
 | 
												
													
														
															|  |      return {
 |  |      return {
 | 
												
													
														
															|  |        type: "writer",
 |  |        type: "writer",
 | 
												
													
														
															|  |        newLine,
 |  |        newLine,
 | 
												
													
														
															|  |        content,
 |  |        content,
 | 
												
													
														
															|  | -    };
 |  | 
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      };
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    if (name === "$read") {
 |  |    if (name === "$read") {
 | 
												
													
														
															|  |      return {
 |  |      return {
 | 
												
													
														
															|  |        type: "reader",
 |  |        type: "reader",
 | 
												
													
														
															|  |        variable: parameters[0],
 |  |        variable: parameters[0],
 | 
												
													
														
															|  | -    };
 |  | 
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      };
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    return {
 |  |    return {
 | 
												
													
														
															|  |      type: "functioncall",
 |  |      type: "functioncall",
 | 
												
													
														
															|  |      parameters_list: parameters,
 |  |      parameters_list: parameters,
 | 
												
													
														
															|  |      name: functionCall.id,
 |  |      name: functionCall.id,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.Function} func
 |  |   * @param {Commands.Function} func
 | 
												
													
														
															|  |   * */
 |  |   * */
 | 
												
											
												
													
														
															|  | @@ -268,22 +275,19 @@ function functionWalker (func) {
 | 
												
													
														
															|  |      parameters_list: [],
 |  |      parameters_list: [],
 | 
												
													
														
															|  |      variables_list: [],
 |  |      variables_list: [],
 | 
												
													
														
															|  |      commands: [],
 |  |      commands: [],
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  |    if (func.returnType instanceof ArrayType) {
 |  |    if (func.returnType instanceof ArrayType) {
 | 
												
													
														
															|  |      funcDeclaration.return_type = func.returnType.innerType.value;
 |  |      funcDeclaration.return_type = func.returnType.innerType.value;
 | 
												
													
														
															|  |      funcDeclaration.return_dimensions = func.returnType.dimensions;
 |  |      funcDeclaration.return_dimensions = func.returnType.dimensions;
 | 
												
													
														
															|  |    } else {
 |  |    } else {
 | 
												
													
														
															|  |      funcDeclaration.return_type = func.returnType.value;
 |  |      funcDeclaration.return_type = func.returnType.value;
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | -  funcDeclaration.parameters_list = func.formalParameters.map(
 |  | 
 | 
												
													
														
															|  | -    functionParameterWalker
 |  | 
 | 
												
													
														
															|  | -  );
 |  | 
 | 
												
													
														
															|  | -  funcDeclaration.variables_list = func.variablesDeclarations.map(
 |  | 
 | 
												
													
														
															|  | -    variableDeclarationWalker
 |  | 
 | 
												
													
														
															|  | -  );
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  | 
 |  | +  funcDeclaration.parameters_list = func.formalParameters.map(functionParameterWalker);
 | 
												
													
														
															|  | 
 |  | +  funcDeclaration.variables_list = func.variablesDeclarations.map(variableDeclarationWalker);
 | 
												
													
														
															|  |    funcDeclaration.commands = func.commands.map(commandWalker);
 |  |    funcDeclaration.commands = func.commands.map(commandWalker);
 | 
												
													
														
															|  |    return funcDeclaration;
 |  |    return funcDeclaration;
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.FormalParameter} formalParameter
 |  |   * @param {Commands.FormalParameter} formalParameter
 | 
												
											
												
													
														
															|  | @@ -299,15 +303,16 @@ function functionParameterWalker (formalParameter) {
 | 
												
													
														
															|  |      value: 0,
 |  |      value: 0,
 | 
												
													
														
															|  |      is_const: false,
 |  |      is_const: false,
 | 
												
													
														
															|  |      reference: formalParameter.byRef,
 |  |      reference: formalParameter.byRef,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  |    if (formalParameter.type instanceof ArrayType) {
 |  |    if (formalParameter.type instanceof ArrayType) {
 | 
												
													
														
															|  |      variable.type = formalParameter.type.innerType.value;
 |  |      variable.type = formalParameter.type.innerType.value;
 | 
												
													
														
															|  |      variable.dimension = formalParameter.type.dimensions;
 |  |      variable.dimension = formalParameter.type.dimensions;
 | 
												
													
														
															|  |    } else {
 |  |    } else {
 | 
												
													
														
															|  |      variable.type = formalParameter.type.value;
 |  |      variable.type = formalParameter.type.value;
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    return variable;
 |  |    return variable;
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  /**
 |  |  /**
 | 
												
													
														
															|  |   * @param {Commands.Declaration} command
 |  |   * @param {Commands.Declaration} command
 | 
												
											
												
													
														
															|  | @@ -323,7 +328,7 @@ function variableDeclarationWalker (command, global = false) {
 | 
												
													
														
															|  |      dimension: 0,
 |  |      dimension: 0,
 | 
												
													
														
															|  |      value: 0,
 |  |      value: 0,
 | 
												
													
														
															|  |      is_const: false,
 |  |      is_const: false,
 | 
												
													
														
															|  | -  };
 |  | 
 | 
												
													
														
															|  | 
 |  | +    };
 | 
												
													
														
															|  |    variable.is_const = global && command.isConst;
 |  |    variable.is_const = global && command.isConst;
 | 
												
													
														
															|  |    if (command instanceof Commands.ArrayDeclaration) {
 |  |    if (command instanceof Commands.ArrayDeclaration) {
 | 
												
													
														
															|  |      // array
 |  |      // array
 | 
												
											
												
													
														
															|  | @@ -332,31 +337,26 @@ function variableDeclarationWalker (command, global = false) {
 | 
												
													
														
															|  |      if (command.isVector) {
 |  |      if (command.isVector) {
 | 
												
													
														
															|  |        variable.columns = lines.value;
 |  |        variable.columns = lines.value;
 | 
												
													
														
															|  |        variable.dimension = 1;
 |  |        variable.dimension = 1;
 | 
												
													
														
															|  | -      const values = command.initial.value.map((exp) =>
 |  | 
 | 
												
													
														
															|  | -        variableInitialWalker(exp)
 |  | 
 | 
												
													
														
															|  | -      );
 |  | 
 | 
												
													
														
															|  | 
 |  | +      const values = command.initial.value.map((exp) => variableInitialWalker(exp) );
 | 
												
													
														
															|  |        variable.value = values;
 |  |        variable.value = values;
 | 
												
													
														
															|  |      } else {
 |  |      } else {
 | 
												
													
														
															|  |        const columns = expressionWalker(command.columns).pop();
 |  |        const columns = expressionWalker(command.columns).pop();
 | 
												
													
														
															|  |        variable.dimension = 2;
 |  |        variable.dimension = 2;
 | 
												
													
														
															|  |        variable.rows = lines.value;
 |  |        variable.rows = lines.value;
 | 
												
													
														
															|  |        variable.columns = columns.value;
 |  |        variable.columns = columns.value;
 | 
												
													
														
															|  | -      const values = command.initial.value.map((rows) =>
 |  | 
 | 
												
													
														
															|  | -        rows.value.map((exp) => variableInitialWalker(exp))
 |  | 
 | 
												
													
														
															|  | -      );
 |  | 
 | 
												
													
														
															|  | 
 |  | +      const values = command.initial.value.map((rows) => rows.value.map((exp) => variableInitialWalker(exp)) );
 | 
												
													
														
															|  |        variable.value = values;
 |  |        variable.value = values;
 | 
												
													
														
															|  | -    }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  |    } else {
 |  |    } else {
 | 
												
													
														
															|  |      // atomic
 |  |      // atomic
 | 
												
													
														
															|  |      variable.type = command.type.value;
 |  |      variable.type = command.type.value;
 | 
												
													
														
															|  |      variable.value = variableInitialWalker(command.initial);
 |  |      variable.value = variableInitialWalker(command.initial);
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    return variable;
 |  |    return variable;
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -/**
 |  | 
 | 
												
													
														
															|  | - * @param {any} expression
 |  | 
 | 
												
													
														
															|  | - * */
 |  | 
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +/// @param {any} expression
 | 
												
													
														
															|  |  function variableInitialWalker (expression) {
 |  |  function variableInitialWalker (expression) {
 | 
												
													
														
															|  |    if (expression instanceof Expressions.UnaryApp) {
 |  |    if (expression instanceof Expressions.UnaryApp) {
 | 
												
													
														
															|  |      const left = variableInitialWalker(expression.left);
 |  |      const left = variableInitialWalker(expression.left);
 | 
												
											
												
													
														
															|  | @@ -373,39 +373,32 @@ function variableInitialWalker (expression) {
 | 
												
													
														
															|  |    } else if (expression instanceof Literal) {
 |  |    } else if (expression instanceof Literal) {
 | 
												
													
														
															|  |      let value = expression.value;
 |  |      let value = expression.value;
 | 
												
													
														
															|  |      if (expression.value.toNumber) {
 |  |      if (expression.value.toNumber) {
 | 
												
													
														
															|  | -      if (
 |  | 
 | 
												
													
														
															|  | -        Types.REAL.isCompatible(expression.type) &&
 |  | 
 | 
												
													
														
															|  | -        expression.value.decimalPlaces() == 0
 |  | 
 | 
												
													
														
															|  | -      ) {
 |  | 
 | 
												
													
														
															|  | 
 |  | +      if (Types.REAL.isCompatible(expression.type) && expression.value.decimalPlaces() == 0) {
 | 
												
													
														
															|  |          value = Number(expression.value.toFixed(2));
 |  |          value = Number(expression.value.toFixed(2));
 | 
												
													
														
															|  |        } else {
 |  |        } else {
 | 
												
													
														
															|  |          value = expression.value.toNumber();
 |  |          value = expression.value.toNumber();
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  |        }
 |  |        }
 | 
												
													
														
															|  | -    }
 |  | 
 | 
												
													
														
															|  |      return value;
 |  |      return value;
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |    throw new Error("invalid variable initial value: " + expression.toString());
 |  |    throw new Error("invalid variable initial value: " + expression.toString());
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -/**
 |  | 
 | 
												
													
														
															|  | - *
 |  | 
 | 
												
													
														
															|  | - * @return {[]}
 |  | 
 | 
												
													
														
															|  | - **/
 |  | 
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +/// @return {[]}
 | 
												
													
														
															|  |  function expressionWalker (expression) {
 |  |  function expressionWalker (expression) {
 | 
												
													
														
															|  |    let result;
 |  |    let result;
 | 
												
													
														
															|  |    if (expression instanceof Expressions.VariableLiteral) {
 |  |    if (expression instanceof Expressions.VariableLiteral) {
 | 
												
													
														
															|  | -    result = [
 |  | 
 | 
												
													
														
															|  | -      { instance: "expression", type: TYPES.VARIABLE, value: expression.id },
 |  | 
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | 
 |  | +    result = [ { instance: "expression", type: TYPES.VARIABLE, value: expression.id }, ];
 | 
												
													
														
															|  |    } else if (expression instanceof Expressions.FunctionCall) {
 |  |    } else if (expression instanceof Expressions.FunctionCall) {
 | 
												
													
														
															|  |      const funcObj = {
 |  |      const funcObj = {
 | 
												
													
														
															|  |        instance: "expression",
 |  |        instance: "expression",
 | 
												
													
														
															|  |        type: TYPES.FUNCTION,
 |  |        type: TYPES.FUNCTION,
 | 
												
													
														
															|  |        value: expression.id,
 |  |        value: expression.id,
 | 
												
													
														
															|  | -    };
 |  | 
 | 
												
													
														
															|  | 
 |  | +      };
 | 
												
													
														
															|  |      const paramsList = expression.actualParameters.map((e) =>
 |  |      const paramsList = expression.actualParameters.map((e) =>
 | 
												
													
														
															|  |        expressionWalker(e)
 |  |        expressionWalker(e)
 | 
												
													
														
															|  | -    );
 |  | 
 | 
												
													
														
															|  | 
 |  | +      );
 | 
												
													
														
															|  |      //const params = Array.prototype.concat.apply([], paramsList);
 |  |      //const params = Array.prototype.concat.apply([], paramsList);
 | 
												
													
														
															|  |      funcObj.params = paramsList;
 |  |      funcObj.params = paramsList;
 | 
												
													
														
															|  |      result = [funcObj];
 |  |      result = [funcObj];
 | 
												
											
												
													
														
															|  | @@ -423,7 +416,7 @@ function expressionWalker (expression) {
 | 
												
													
														
															|  |        ...left,
 |  |        ...left,
 | 
												
													
														
															|  |        { instance: "operator", type: opType, value: opValue },
 |  |        { instance: "operator", type: opType, value: opValue },
 | 
												
													
														
															|  |        ...right,
 |  |        ...right,
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | 
 |  | +      ];
 | 
												
													
														
															|  |    } else if (expression instanceof Expressions.ArrayAccess) {
 |  |    } else if (expression instanceof Expressions.ArrayAccess) {
 | 
												
													
														
															|  |      const line = expressionWalker(expression.line);
 |  |      const line = expressionWalker(expression.line);
 | 
												
													
														
															|  |      let arrayClass = "vector";
 |  |      let arrayClass = "vector";
 | 
												
											
												
													
														
															|  | @@ -431,27 +424,25 @@ function expressionWalker (expression) {
 | 
												
													
														
															|  |      if (expression.column) {
 |  |      if (expression.column) {
 | 
												
													
														
															|  |        arrayClass = "matrix";
 |  |        arrayClass = "matrix";
 | 
												
													
														
															|  |        column = expressionWalker(expression.column);
 |  |        column = expressionWalker(expression.column);
 | 
												
													
														
															|  | -    }
 |  | 
 | 
												
													
														
															|  | -    result = [
 |  | 
 | 
												
													
														
															|  | -      {
 |  | 
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  | 
 |  | +    result = [ {
 | 
												
													
														
															|  |          instance: "expression",
 |  |          instance: "expression",
 | 
												
													
														
															|  |          type: TYPES.VARIABLE,
 |  |          type: TYPES.VARIABLE,
 | 
												
													
														
															|  |          class: arrayClass,
 |  |          class: arrayClass,
 | 
												
													
														
															|  |          column: column,
 |  |          column: column,
 | 
												
													
														
															|  |          line: line,
 |  |          line: line,
 | 
												
													
														
															|  |          value: expression.id,
 |  |          value: expression.id,
 | 
												
													
														
															|  | -      },
 |  | 
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | 
 |  | +        },
 | 
												
													
														
															|  | 
 |  | +      ];
 | 
												
													
														
															|  |    } else if (expression instanceof Expressions.BoolLiteral) {
 |  |    } else if (expression instanceof Expressions.BoolLiteral) {
 | 
												
													
														
															|  |      const value = expression.value;
 |  |      const value = expression.value;
 | 
												
													
														
															|  | -    result = [
 |  | 
 | 
												
													
														
															|  | -      {
 |  | 
 | 
												
													
														
															|  | 
 |  | +    result = [ {
 | 
												
													
														
															|  |          instance: "expression",
 |  |          instance: "expression",
 | 
												
													
														
															|  |          class: "simple",
 |  |          class: "simple",
 | 
												
													
														
															|  |          type: TYPES.CONST,
 |  |          type: TYPES.CONST,
 | 
												
													
														
															|  |          value: convertBoolToString(value),
 |  |          value: convertBoolToString(value),
 | 
												
													
														
															|  | -      },
 |  | 
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | 
 |  | +        },
 | 
												
													
														
															|  | 
 |  | +      ];
 | 
												
													
														
															|  |    } else {
 |  |    } else {
 | 
												
													
														
															|  |      let value = expression.value;
 |  |      let value = expression.value;
 | 
												
													
														
															|  |      if (expression.value.toNumber) {
 |  |      if (expression.value.toNumber) {
 | 
												
											
												
													
														
															|  | @@ -462,31 +453,34 @@ function expressionWalker (expression) {
 | 
												
													
														
															|  |          value = Number(expression.value.toFixed(2));
 |  |          value = Number(expression.value.toFixed(2));
 | 
												
													
														
															|  |        } else {
 |  |        } else {
 | 
												
													
														
															|  |          value = expression.value.toNumber();
 |  |          value = expression.value.toNumber();
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  |        }
 |  |        }
 | 
												
													
														
															|  | 
 |  | +    result = [ { instance: "expression", class: "simple", type: TYPES.CONST, value: value, }, ];
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  | -    result = [
 |  | 
 | 
												
													
														
															|  | -      {
 |  | 
 | 
												
													
														
															|  | -        instance: "expression",
 |  | 
 | 
												
													
														
															|  | -        class: "simple",
 |  | 
 | 
												
													
														
															|  | -        type: TYPES.CONST,
 |  | 
 | 
												
													
														
															|  | -        value: value,
 |  | 
 | 
												
													
														
															|  | -      },
 |  | 
 | 
												
													
														
															|  | -    ];
 |  | 
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  |    if (expression.parenthesis) return ["(", ...result, ")"];
 |  |    if (expression.parenthesis) return ["(", ...result, ")"];
 | 
												
													
														
															|  |    else return result;
 |  |    else return result;
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  export function parseExpression (text) {
 |  |  export function parseExpression (text) {
 | 
												
													
														
															|  |    const parser = IVProgParser.createParser(text);
 |  |    const parser = IVProgParser.createParser(text);
 | 
												
													
														
															|  |    const expressionAST = parser.parseExpressionOR();
 |  |    const expressionAST = parser.parseExpressionOR();
 | 
												
													
														
															|  |    return expressionWalker(expressionAST);
 |  |    return expressionWalker(expressionAST);
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -/**
 |  | 
 | 
												
													
														
															|  | - * @param {string} text
 |  | 
 | 
												
													
														
															|  | - * */
 |  | 
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +/// @param {string} text
 | 
												
													
														
															|  | 
 |  | +/// @calledby js/util/iassignHelpers.js!setPreviousAlgorithm(code)
 | 
												
													
														
															|  |  export function parseCode (text) {
 |  |  export function parseCode (text) {
 | 
												
													
														
															|  | 
 |  | +  console.log("js/util/parseFromVisual.js!parseCode(text): can this function be removed? If is it appearing in log, then no...");
 | 
												
													
														
															|  | 
 |  | +  //D console.trace();
 | 
												
													
														
															|  | 
 |  | +  return parserCodeVisual(text);
 | 
												
													
														
															|  | 
 |  | +  }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +/// @param {string} text
 | 
												
													
														
															|  | 
 |  | +/// @calledby js/util/iassignHelpers.js!setPreviousAlgorithm(code)
 | 
												
													
														
															|  | 
 |  | +export function parserCodeVisual (text) { // Gleyce
 | 
												
													
														
															|  | 
 |  | +  console.log("js/util/parseFromVisual.js!parserCodeVisual(text): starting");
 | 
												
													
														
															|  | 
 |  | +  //D console.trace();
 | 
												
													
														
															|  |    const parser = IVProgParser.createParser(text, false);
 |  |    const parser = IVProgParser.createParser(text, false);
 | 
												
													
														
															|  |    const codeLinesMap = new Map();
 |  |    const codeLinesMap = new Map();
 | 
												
													
														
															|  |    const tokens = Array.from(parser.lexer.reset(text));
 |  |    const tokens = Array.from(parser.lexer.reset(text));
 | 
												
											
												
													
														
															|  | @@ -494,29 +488,63 @@ export function parseCode (text) {
 | 
												
													
														
															|  |    for (const token of tokens) {
 |  |    for (const token of tokens) {
 | 
												
													
														
															|  |      if (token.type === parser.ruleNames.ERROR) {
 |  |      if (token.type === parser.ruleNames.ERROR) {
 | 
												
													
														
															|  |        return null;
 |  |        return null;
 | 
												
													
														
															|  | -    }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  |      if (token.type === parser.ruleNames.COMMENTS) {
 |  |      if (token.type === parser.ruleNames.COMMENTS) {
 | 
												
													
														
															|  |        for (let i = 0; i <= token.lineBreaks; i++) {
 |  |        for (let i = 0; i <= token.lineBreaks; i++) {
 | 
												
													
														
															|  |          if (codeLinesMap.has(i + token.line))
 |  |          if (codeLinesMap.has(i + token.line))
 | 
												
													
														
															|  |            codeLinesMap.get(i + token.line).push(token);
 |  |            codeLinesMap.get(i + token.line).push(token);
 | 
												
													
														
															|  |          else codeLinesMap.set(i + token.line, [token]);
 |  |          else codeLinesMap.set(i + token.line, [token]);
 | 
												
													
														
															|  | -      }
 |  | 
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  |        continue;
 |  |        continue;
 | 
												
													
														
															|  | -    }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  |      if (token.type !== parser.ruleNames.WHITESPACE) {
 |  |      if (token.type !== parser.ruleNames.WHITESPACE) {
 | 
												
													
														
															|  |        tokenStream.push(token);
 |  |        tokenStream.push(token);
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  |    parser.fill(tokenStream);
 |  |    parser.fill(tokenStream);
 | 
												
													
														
															|  |    try {
 |  |    try {
 | 
												
													
														
															|  |      const program = parser.parseTree();
 |  |      const program = parser.parseTree();
 | 
												
													
														
															|  |      const globals = program.global.map((decl) =>
 |  |      const globals = program.global.map((decl) =>
 | 
												
													
														
															|  |        variableDeclarationWalker(decl, true)
 |  |        variableDeclarationWalker(decl, true)
 | 
												
													
														
															|  | -    );
 |  | 
 | 
												
													
														
															|  | 
 |  | +      );
 | 
												
													
														
															|  |      const functions = program.functions.map(functionWalker);
 |  |      const functions = program.functions.map(functionWalker);
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +    //Gleyce start: new code to read IVPH file with comment (//)
 | 
												
													
														
															|  | 
 |  | +    const allComments = [];
 | 
												
													
														
															|  | 
 |  | +    for (const [line, commentTokens] of codeLinesMap.entries()) {
 | 
												
													
														
															|  | 
 |  | +      for (const token of commentTokens) {
 | 
												
													
														
															|  | 
 |  | +        const commentText = token.text.replace(/^\/\//, '').trim();
 | 
												
													
														
															|  | 
 |  | +        allComments.push({
 | 
												
													
														
															|  | 
 |  | +          type: "comment",
 | 
												
													
														
															|  | 
 |  | +          comment_text: commentText,
 | 
												
													
														
															|  | 
 |  | +          line: token.line,
 | 
												
													
														
															|  | 
 |  | +          });
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  | 
 |  | +    const astFunctions = program.functions;
 | 
												
													
														
															|  | 
 |  | +    functions.forEach((visualFunc, index) => {
 | 
												
													
														
															|  | 
 |  | +      const astFunc = astFunctions[index];
 | 
												
													
														
															|  | 
 |  | +      const funcStartLine = astFunc.sourceInfo.line;
 | 
												
													
														
															|  | 
 |  | +      let funcEndLine;
 | 
												
													
														
															|  | 
 |  | +      if (astFunctions[index + 1]) {
 | 
												
													
														
															|  | 
 |  | +        funcEndLine = astFunctions[index + 1].sourceInfo.line;
 | 
												
													
														
															|  | 
 |  | +      } else {
 | 
												
													
														
															|  | 
 |  | +        funcEndLine = Infinity;
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +      const funcComments = allComments.filter(comment =>
 | 
												
													
														
															|  | 
 |  | +        comment.line > funcStartLine && comment.line < funcEndLine
 | 
												
													
														
															|  | 
 |  | +        );
 | 
												
													
														
															|  | 
 |  | +      if (funcComments.length > 0) {
 | 
												
													
														
															|  | 
 |  | +        const allCommands = [...visualFunc.commands, ...funcComments];
 | 
												
													
														
															|  | 
 |  | +        allCommands.sort((a, b) => a.line - b.line);
 | 
												
													
														
															|  | 
 |  | +        visualFunc.commands = allCommands;
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +      });
 | 
												
													
														
															|  | 
 |  | +    //Gleyce end: new code to read IVPH file with comment (//)
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |      return { globals, functions };
 |  |      return { globals, functions };
 | 
												
													
														
															|  |    } catch (e) {
 |  |    } catch (e) {
 | 
												
													
														
															|  |      console.error(e);
 |  |      console.error(e);
 | 
												
													
														
															|  |      return null;
 |  |      return null;
 | 
												
													
														
															|  | -  }
 |  | 
 | 
												
													
														
															|  | -}
 |  | 
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  | 
 |  | +  }
 |