Interface NestedStructureHouseKeeper

All Known Implementing Classes:
AbstractNestedStructureHouseKeeper, GenericNestedStructureHouseKeeper

public interface NestedStructureHouseKeeper
Object implementing this interface keep track of the programming structures that can be nested into each other. For example loops, functions and procedures and so on.
Author:
Peter Verhas date June 8, 2012
  • Method Details

    • push

      void push​(java.lang.Class<?> klass, NestedStructure element)
      Push a nested structure object on the housekeeping stack.
      Parameters:
      element - the element to be stored on the stack.
      klass - is the class that we will expect when we pop this element off
    • push

      void push​(NestedStructure element)
      Push a nested structure object on the housekeeping stack. This version of push does push the object associated with the actual class of the object.
      Parameters:
      element - to push on the stack.
    • pop

      <T extends NestedStructure> T pop​(java.lang.Class<T> expectedClass) throws AnalysisException
      Pops one element from the stack.

      Note that nested element have to be pushed on the stack nested. If we get an element off the stack that was not expected it means syntax error and therefore in this case exception is thrown.

      When exception was thrown the functioning of the object is not defined by this interface. Some implementation may seek the appropriate element in the stack and throw off all top element until a proper type of element is found assuming that the user forgot to close some internal programming structured in the scripted language. Other implementations may follow more complex strategy to recover from such an error. In either case the sole reason of further syntax analysis is to discover as many syntax error as possible following the first one.

      Type Parameters:
      T - expected type of the element
      Parameters:
      expectedClass - the expected class of the element
      Returns:
      the top element
      Throws:
      AnalysisException - when the top element of the stack is not the type that we expect
    • checkFinalState

      void checkFinalState() throws AnalysisException
      Check final state of nested structures. Check if there are no opened nested structures or any other pending blocks.
      Throws:
      AnalysisException - when there are some elements on the stack
    • consumeEndOfStatement

      void consumeEndOfStatement() throws AnalysisException
      Checks that there are no extra characters when the line analyzer expects it has finished analyzing the statement. If there are some extra characters on the line then throws syntax error exception. Otherwise it simply steps the lexical analyzer iterator over the symbol.
      Throws:
      AnalysisException - when there are extra character on the actual line
    • pushEndOfStatementProcessor

      void pushEndOfStatementProcessor​(NestedStructureHouseKeeper.EndOfStatementProcessor endOfStatementProcessor)
    • popEndOfStatementProcessor