Package eu.bandm.tscore.base


package eu.bandm.tscore.base
Generic and low level data types and transformation algorithms, to be used by very different applications of the tscore framework.

The basic processing pipeline is as follows:
  1. The lexer TScoreLexer translates some text input into a token stream.
  2. This is fed into a hand-written, recursive descent parser in RawParser. This creates an instance of the umod model from eu.bandm.tscore.model Here the items one level below the mere event structure are still unparsed.
  3. Therefore, in a second step specialized, dedicated parsers must be called for further translation, depending on the concrete score format.
    The parsers must be derived from Translet.Parser. Their output data in most cases will be encoded in instances of classes derived from Entity.

The functionality is not at all restricted to conventional music notation. Nevertheless this realm is supported by further packages built upon this basic framework:

See also the user documentation
  • Class
    Description
    For musical purposes it is utmost convenient to support the "dotted notation", using "prolongation dots", short "dots".
    Class for debugging purpose which prints unparsed tscore event sequences.
    Entity<E extends Entity>
    Base class for all things which are in a certain multi-lingual catalog, and have a common parser for their symbolic appearance in scores, and which form a common semantic domain.
    Contains collection of basic score entities used as parameter values, indexed and documented in a multi lingual way.
    Looks for start/end of pattern repetition and constructs the representing Event ->Event relation.
     
    Collects sets of adjacent events from one single voice.
    Kind of group commands, to be stored in GroupCollector.GroupEvent.
    An instance of this class is used to parametrize the raw parsing process and the subsequent first transformations, as performed by RawParser and the methods in Util.
    Encodes how the code will react to a specific input condition.
    Looks for repettions of a pattern in a certain parameter track and distributes it event-wise to the successor events.
    States of the state machine.
    Recursive-descent parser for the raw level of tscore.
    Processes a parameter track which contains tendencies spanning more than one Event.
     
    Base class for constructing user defined parsers by combinators; originally for the values contained in the different parameter tracks of a tscore voice.
    Implements a greedy longest prefix match from a collection of strings.
    Parser for a simple string constant which must appear verbatim, as is.
    Parser for text input following a regular expression.
    Realizes a protocol tree of alternatives to the parsing results.
    Common superclass for Parsers which accept one of many alternatives and return a CoTuple (ORn and PRIORn).
    Kinds of disjunctive parser combinators.
    Common superclass for Parsers which accept one of many alternatives.
    Format printer which puts maximally one ParserFormat to each screen column and memorizes this for later alignment of consumed char data.
    Accepts a sequence "A,B,C", where only the middle parsing/processing result is stored as result in the Translet.State object, discarding the frame.
    Accepts a sequence "A,B,..", where only the very first parsing/processing result is stored as result in the Translet.State object, discarding all the tail.
    Common superclass for Parsers which accept one of many alternatives and return the upper limit of the different result classes (OR1 and PRIOR1).
    Option parser, in greedy and non-deterministic variant, with or without default value.
    Realizes disjunction which is nondeterministic and returns a CoTuple.
    Realizes disjunction which is nondeterministic and returns an upper limit class.
    Used to retrieve a Translet.Parser in a particular (human) language, to plug it into the tscore parsing process.
    Base class for all parser classes, contains most of the working methods.
    Specialized Format which refers to a Parser for alignment of char data.
    Translet.PermutationParser<R,A,B,C,D,E,F,G,H>
    Variant of Translet.ProductParser which accepts all permutations of sub-parsers.
    Repetition parser which does not allow allow empty list as result.
    Realizes disjunction which is priorized and returns a CoTuple.
    Realizes disjunction which is priorized and returns an upper limit class.
    Translet.ProductParser<R,A,B,C,D,E,F,G,H>
    Common superclass for Parsers which produce a product type as their result.
    A placeholder which can be embedded into a parser construct, and later be assigned the complete parser as a whole, for recursive use.
    Common superclass for Translet.StarParser and Translet.PlusParser.
    Translet.SequParser<R,A,B,C,D,E,F,G,H>
    Variant of Translet.ProductParser which accepts a certain sequence of sub-parsers.
    Repetition parser which allows empty list as result.
    Central data type for parser operation.
    Common superclass of the storing oeprators.
    Storing operator which only one(1) value per key.
    Storing operator which can store multiple (>1) values per key, preserving the sequential order in the source.
    Storing operator which can store multiple (>1) values per key.
    Library of universal Translet parsers, and of auxiliary functions to be used in such parsers.
    Filters the result of its sub-parser by an explicit Java-encoded boolean predicate.
    Collection of static utility methods.
    Employed for the central map from a "naturally" ordered arithmetic type (like Rational, BigInteger, etc.) to Tp objects representing time points, allowing their time-respecting traversal.
    Step through all time points and process the tuple of events from all voices which are currently "sounding".