class PACKRAT_NOT
Summary
Direct parents
Inherit list: PACKRAT_LOOKAHEAD
Class invariant
Overview
out_in_tagged_out_memory
effective procedure
{ANY}
require
    • locked: tagged_out_locked
      • locked: tagged_out_locked
      • locked: tagged_out_locked
ensure
  • still_locked: tagged_out_locked
  • not_cleared: tagged_out_memory.count >= old tagged_out_memory.count
  • append_only: old tagged_out_memory.twin.is_equal(tagged_out_memory.substring(1, old tagged_out_memory.count))
accept (visitor: PACKRAT_VISITOR)
effective procedure
{ANY}
Accept to be visited by the visitor.
require
  • visitor /= Void
pack_parse (context: PACKRAT_PARSE_CONTEXT): TRISTATE
effective function
{}
require
  • context /= Void
ensure
  • not Result.is_equal(yes) implies context.buffer.current_index = old context.buffer.current_index
is_coherent: BOOLEAN
effective function
{ANY}
ensure
  • must_be_coherent: Result
is_equal (other: PACKRAT_NOT): BOOLEAN
effective function
{ANY}
require
    • other /= Void
      • other /= Void
      • other /= Void
ensure
  • commutative: generating_type = other.generating_type implies Result = other.is_equal(Current)
copy (other: PACKRAT_NOT)
effective procedure
{ANY}
require
    • not immutable
    • same_dynamic_type(other)
      • not immutable
      • same_dynamic_type(other)
      • not immutable
      • same_dynamic_type(other)
ensure
  • is_equal(other)
set_default_tree_builders (non_terminal_builder: PROCEDURE[TUPLE 2[FIXED_STRING, TRAVERSABLE[FIXED_STRING]]], terminal_builder: PROCEDURE[TUPLE 2[FIXED_STRING, PARSER_IMAGE]])
effective procedure
set_nt (a_nt: PACKRAT_NON_TERMINAL)
effective procedure
require
  • a_nt /= Void
ensure
  • nt = a_nt
make (a_primary: PACKRAT_PRIMARY)
effective procedure
{}
require
  • a_primary /= Void
ensure
primary: PACKRAT_PRIMARY
writable attribute
effective function
{ANY}
require
  • other /= Void
hash_code: INTEGER_32
effective function
{ANY}
The hash-code value of Current.
ensure
  • good_hash_value: Result >= 0
positive_lookahead: PACKRAT_ALTERNATIVE
frozen
effective function
{ANY}
prefix "@": PACKRAT_ALTERNATIVE
effective function
{ANY}
negative_lookahead: PACKRAT_ALTERNATIVE
frozen
effective function
{ANY}
prefix "~": PACKRAT_ALTERNATIVE
effective function
{ANY}
parse (context: PACKRAT_PARSE_CONTEXT): TRISTATE
frozen
effective function
require
  • context /= Void
ensure
  • not Result.is_equal(yes) implies context.buffer.current_index = old context.buffer.current_index
writable attribute
set_paren (a_paren: BOOLEAN)
effective procedure
ensure
need_paren: BOOLEAN
writable attribute
log: LOGGER
effective function
{}
There is one logger per concrete type; for performance reasons it is cached in each instance.
ensure
  • Result /= Void
log_memory__0_: LOGGER
writable attribute
{}
The cached logger.
The ugly name is intentional. Don't use directly.
yes: TRISTATE
effective function
{ANY}
effective function
{ANY}
maybe: TRISTATE
effective function
{ANY}