Related articles |
---|
New Tools for Language Processor Development xorian@solomon.technet.sg (1992-05-11) |
Newsgroups: | comp.compilers |
From: | xorian@solomon.technet.sg (Xorian Technologies) |
Keywords: | tools, C++ |
Organization: | Compilers Central |
Date: | Mon, 11 May 1992 09:26:35 GMT |
Xorian Technologies Pte. Ltd. has available a comprehensive translator
generator toolkit LADE (LAnguage Definition Environment, pronounced
lay-dee). LADE is a powerful line of tools intended to aid in the design
and development of language processors including compilers, translators
and interpreters for computer languages, 4th generation languages (4GLs),
and application front ends in C++.
LADE is not yet another Yacc clone. While subsuming the capabilities of
Yacc, it goes far beyond that which has heretofore been provided in
production quality translator-generator tools. LADE supports the
development of all phases of language design and implementation including
lexical, syntactic, and semantic analysis, as well as code generation.
Among the more notable features of LADE:
o Genuine Regular Expression LALR(1) Grammars
LADE grammars are regular-LALR(1) which means, for example, that
instead of writing:
x -> a | x a ;
you can write:
x -> [x] a ;
or even:
{a}
instead of x. Moreover, this regularity is not a transformation on the
source grammar but is intrinsic to the state machine which is
generated. As a result, not only do regular expressions not introduce
conflicts which may result from a simple trasformation on the grammar,
but regular expressions may actually remove conflicts by deferring
shift-reduce and reduce-reduce decisions by the parser until the
regular expression is completely read. Regular expressions
significantly reduce the size and complexity of languages and reduce the
requirements for additional intermediate representations for semantic
analysis as well as facilitating the design of new languages.
Regular expressions are fully supported in the translator specification
which is extremely important when the length of a production is unknown
at run-time. Instead of referring to elements by their offset on the
parser stack, they are referred to by name.
o Context Sensitivity
LADE grammars may be supplemented by context sensitive tests. The
computation of these tests are defined in the translator specification
and, therefore, have full access to all lexical, syntactic, and
semantic information. The result of the test determines whether a
given production should be reduced or not. For example, an Ada
function call may be distinguished from an array reference by testing
for a compatible declaration for each.
Using context-sensitive tests and regular expressions, a C++ parser
has been produced with zero (0) shift-reduce and zero (0) reduce-reduce
conflicts using essentially the grammar described in The Annotated
Reference Manual for C++.
o Fully Automatic Syntactic Error Recovery Generation
Every language processor produced by LADE automatically detects,
reports, and recovers from syntactic errors. Automatic syntactic error
may be fine tuned by affixing specific costs associated with the
addition or deletion of specific lexemes.
o GUI-based Grammar and Parser Debuggers
The parser debugger, LADEBug, allows a running parser to be traced and
examined. It presents a visual representation of an executing parser
and takes advantage of a graphical user interface to provide ease of
use, as well as organizes the debugging information logically for
easy reference and access. Each parser action taken by the parser may
be traced and stepped through. Breakpoints may be set such that the
parse will stop at the set condition. The current lookahead symbol
and its location in the input is dynamically marked and updated. The
parse stack is visually represented and is dynamically updated. Values
of elements on the parse stack may have their attribute values examined.
The grammar debugger is a generate time debugger that is used to examined
shift reduce and reduce reduce conflicts. Conflicts are systematically
organized and may be examined in detail. A trace of how the conflicting
symbol is introduced and how the conflict derives us used to provide
the user with more information on the conflict. In addition, state and
production information may be easily called up for quick reference.
o Translator Modularity for Layered Reuse
LADE may be used to specify translator modules which may be reused
either vertialy, by adding new nonterminals and productions, or
horizontally by attaching additional semantics to previously defined
nonterminals and productions. For example, an ANSI C semantic checking
module may be reused to specify either a compiler front end or a
preprocessor.
o Integral Object-Oriented Design
LADE utilizes object-oriented design in a number of ways including the
language processor objects and the organization of the translator
modules.
o Reentrant and Multiple Parser Instances
Because each language processor generated by LADE is a first-class C++
object, an application may contain an arbitrary number of such
processors and may recursively re-invoke the parser.
o Attribute-Based Semantic Support
Language processor semantics are specified by an essentially
L-attributed specification. Additionaly, dynamic attributes may be
attached to nonterminals to perform multi-pass analysis and code-
generation.
o Translator Specification is a Superset of C++
The attribute-based specification is a superset of C++. Semantic actions
may be specified as C++ expressions or compound statements and C++
declarations may be included in the translator specifications.
o LADE is defined in LADE
LADE largely consists of a set of language processors each of which is
defined in LADE.
Availability
LADE is currently available for the Sun Microsystems Sparcstation
processor and requires OpenLook for its debugging tools. Support for
other platforms will be available soon where interest is indicated.
LADE will begin shipping by the end of May 1992. For further
information or a demo kit, contact:
Xorian Technologies Pte. Ltd.
389A Balestier Road
Singapore 1232
Republic of Singapore
Tel: (65)256-1532, Fax: (65)253-7709, email: xorian@solomon.technet.sg
--
Return to the
comp.compilers page.
Search the
comp.compilers archives again.