A language parser is a software program, which takes as input a text stream that meets a particular language specification, and provides in response a parse tree or Abstract Syntax Tree (AST). The AST expresses a fundamental structure of the particular language and can be used to generate code in that language. A language writer is a complementary program that takes as input the AST and generates code in the chosen language.
A compiler-compiler or parser generator is a utility for generating the source code of a parser, interpreter or compiler from an annotated language description. Depending upon the type of parser that should be generated, these routines may construct a parse tree (or AST), or generate executable code directly.
Generally, language parsing tools such as YACC or Bison (YACC is a UNIX parser tool and Bison is a GNU implementation of YACC) leave the task of defining the AST to the person using the tool. The developer may build and maintain a set of data structures to represent the AST. In addition, changes to the language specification may result in changes to the grammar specification, to data structure definitions for the AST, and to the language rule processing code, which constructs the AST. This means that changes to the grammar definition for the language may cause changes in three separate areas of the code.
Embodiments of the present invention relate to a system and method for generating an extensible Markup Language (XML)-based language parser and writer. XML documents are by definition tree structures, and XML Document Object Model (DOM) implementations provide a general purpose tree data structure. To eliminate the need for maintenance of a custom-built set of data structures for each particular language, XML is used to define the AST in one embodiment. An XML-based schema for describing the rules of a particular language is employed in a process for creating a recursive-descent parser from an XML document, which adheres to the XML-based schema of the language.
In accordance with one aspect of the present invention, a computer-implemented method for generating XML-based parser and writer is provided. The method includes receiving a language definition, generating a parser based on the language definition, receiving an input text that adheres to the language definition, and transforming the input text into an Abstract Syntax Tree (AST) employing the parser. The AST reflects the input text in compliance with the language definition.
The method may further include in a parsing mode, generating a function header upon finding a rule tag and generating an AST node for each token associated with the rule tag such that each node is based on a type of the token. In a writing mode, the method may include generating code upon finding a tag for an AST construct and generating a phrase that adheres to the language definition for each node within the AST construct such that the nodes are arranged in an XML-tree structure.
Embodiments of the present invention now will be described more fully hereinafter with reference to the accompanying drawings, which form a part hereof, and which show, by way of illustration, specific exemplary embodiments for practicing the invention. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Among other things, the present invention may be embodied as methods or devices. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. The following detailed description is, therefore, not to be taken in a limiting sense.
Illustrative Operating Environment
Referring to
Computing device 100 may also have additional features or functionality. For example, computing device 100 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape. Such additional storage is illustrated in
Computing device 100 also contains communications connection(s) 116 that allow the device to communicate with other computing devices 118, such as over a network or a wireless mesh network. Communications connection(s) 116 is an example of communication media. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. The term computer readable media as used herein includes both storage media and communication media.
In one embodiment, applications 106 further include parser-writer generator 122. Parser-writer generator 122 is arranged to generate parser module 124 that takes text in a selected language as input and creates an AST for the language. In generating parser module 124, parser-writer generator 122 uses language definitions for the selected language. Parser-writer generator 122 is further arranged to generate writer module 126 that takes the AST as input and creates text in the selected language. The functionality represented by parser-writer generator 122 may be further supported by additional input devices, 112, output devices 114, and communication connection(s) 116 that are included in computing device 100 for generating parser module 124 and writer module 126.
Illustrative Embodiments For Generating XML-based Language Parser and Writer
Embodiments of the present invention are related to generating an XML-based parser and a writer. In one embodiment, a parser-writer generator, takes as input a language definition and adheres to a schema for defining languages, by means of specifying rules. The parser-writer generator produces as output ‘code’ for a language parser. The produced parser accepts as input text, and in the event that the input text adheres to the rules defined by the language definition, the parser will generate an XML Document Object Model (DOM) in accordance with the language definition used to produce the parser. The parser performs recursive decent parsing. Accordingly, the parser is defined by the rules of the language.
In another embodiment, the parser-writer generator takes as input the language definition and produces as output ‘code’ for a writer. The writer, given an XML DOM that adheres to the AST defined by the language definition, generates text in accordance with the language definition that is used to produce the writer.
Embodiments of the present invention may be applied to standards-based languages, non-standard languages, or modified standards-based languages (“dialects”). Because the parser and the writer are generated based on the rules of the particular language, the parser-writer generator is independent of any particular language.
Parser-writer generator 216 is arranged to receive a language definition document (LDD) from language definition database 214 for a particular language and generate writer 210 and parser 212 for that language. Parser 210 is arranged to receive input text 202 in the selected language and create AST 208 for the language. For example, input text may include command lines: SELECT (fields), FROM (table). Parser 212 may generate an AST that includes node <SELECT_CLAUSE> with child node fields and node <FROM_CLAUSE> with child node table. A developer may modify the AST to add child node more fields to node <SELECT_CLAUSE>.
Once the AST is constructed, writer 210 may receive AST 208 and create output text 204 in the selected language. In the above described example, output text 204 based on AST 208 is SELECT (fields, more fields), FROM (table).
In one operation mode, parser-writer generator acts as parser generator 304 and creates parser code 306. In another operation mode parser-writer generator acts as writer generator 316 and creates writer code 318. Both codes are then compiled into software programs, which is used to process the language.
Language compiler/interpreter 308 may be used to compile parser code 306. Language compiler/interpreter 320 may be used to compile writer code 318. In one embodiment, both language compiler/interpreters 308 and 320 may be external compilers.
Language parser 310, compiled by language compiler/interpreter 308 is arranged to receive input text from input document 312, which adheres to language definition 302. Similarly, language writer 322, compiled by language compiler/interpreter 320 is arranged to receive an AST for the language that adheres to schema implied by language definition 302.
Based on the input from input document 312, language parser 310 provides AST 314 that reflects the input document and adheres to the schema implied by language definition 302.
In the writer operation, language writer 322 provides output document 326 that reflects AST 324 and adheres to the schema implied by language definition 302.
At block 404, rules for the selected language are selected. In one embodiment, a number of default rule sets may be stored in a language rules database and retrieved based on the selection of the language at block 402. In another embodiment, the rules may be provided by a developer for the selected language. Processing proceeds from block 404 to decision block 406.
At decision block 406, a determination is made whether a parser tag is found in the input text. If the decision is that the parser tag is not found, processing returns to block 402. Otherwise, processing advances to decision block 408.
At decision block 408, a determination is made whether a rule tag is found in the input text. If the decision is that the rule tag is not found, processing again returns to block 402. If the rule tag is found, processing moves to block 410.
At block 410, a function header is generated. Parser module operates by checking the input text for tokens and determining which node is to be generated for the AST in response to each token. Processing then moves to block 412.
At block 412, a token is recognized. A number of tokens may vary depending on the complexity of the language that is being parsed. For illustration purposes, processes of parsing five different tokens are described here. Embodiments of the present invention may be implemented with fewer or additional tokens.
Processing moves from block 412 to decision block 414. As mentioned above, five different tokens are examined for illustration purposes. The first such token is a rule token. At decision block 414, a determination is made whether a rule is encountered. If a rule is not encountered, processing advances to decision block 418 to check if another token is found. Otherwise, processing moves to block 416.
At block 416 a call of the rule is generated (e.g. rulename: word) such that the rule can be called anywhere in the input text. From block 416, processing returns to block 412 to look for the next token.
At decision block 418, a determination is made whether a repeat token is encountered. If a repeat token is not encountered, processing advances to decision block 422 to check if another token is found. Otherwise, processing moves to block 420.
At block 420 a loop condition is generated based on the specific token (e.g. while (peek_token=“,”) generates a loop that continues as long as “,” is found). From block 420, processing returns to block 412 to look for the next token.
At decision block 422, a determination is made whether a repeat nesting token is encountered. If a repeat nesting token is not encountered, processing advances to decision block 426 to check if another token is found. Otherwise, processing moves to block 424.
At block 424 a number of nested constructs are generated based on the specific token (e.g. select(fields) from(table) where (graduation_year=“95” and major=“science” and age=“21”) generates a “where” construct within a “from” construct that is within a “select” construct. Furthermore, three additional “and” conditions are generated within the “where” construct. An AST for this example may look like following:
From block 420, processing returns to block 412 to look for the next token.
At decision block 426, a determination is made whether a branch token is encountered. If a branch token is not encountered, processing advances to decision block 430 to check if another token is found. Otherwise, processing moves to block 428.
At block 428 an “if/else if” structure is generated based on the specific path. For example, select (fields, functions) generates an “if” structure for fields path and another “if” structure for functions path. Within one branch structure any number of other branches may be generated. An end branch token may terminate the branch structures. From block 428, processing returns to block 412 to look for the next token.
At decision block 430, a determination is made whether an “optional” token is encountered. An “optional” token is configured to indicate an “if” condition based on various clauses. If the “optional” token is not encountered, processing advances to decision block 434 to check if an end token is found. Otherwise, processing moves to block 432.
At block 432 an “if” condition is generated based on the specific token(s). From block 432, processing returns to block 412 to look for the next token.
As mentioned before, combinations for decision and action blocks for other types of tokens may be employed in addition to the example block described above. After all checking for all types of tokens is completed, processing moves to decision block 434, where a determination is made whether an end token is found. If an end token is found at decision block 434, parsing process terminates. Otherwise, processing advances to block 412 for the next token.
Actions described here are for illustration purposes only. Embodiments may be implemented with fewer or additional blocks or other orders of the actions. For example, a “seetoken” tag may generate code which increments a current lexical token pointer. Tags designated as “other” may refer to any tag, which is not a parser schema tag. An “other” tag may result in generated code that adds a node to the AST tree as a child of the current node on the “stack”. Subsequently, the new node is pushed on the stack. At such time as a matching end tag is seen, code is generated to remove that node off the stack. This is one of the essential mechanisms by which the tree is constructed.
A process of writing text in a selected language essentially mirrors process 400 for parsing. Upon selection of a language and retrieval of language rules for the selected language, an AST is provided as input. A writer module looks for tags in the AST (XML tree) instead of tokens in process 400.
For each tag found an associated rule is applied with the provided value for the rule and text constructed accordingly. Similar to process 400, a number of tags may vary depending on the complexity of the language in which the output text is being written.
Example rule 550 of
Example rule 600 for “word” includes rule_name 602, repeat construct 606, branch construct 608 and path construct 610 for searching the path for tokens such as letter (612) or apostrophe. Additionally, AST nodes 604 and 614 (<ot: Word> and </ot: Word>) are placed immediately after the call for the rule and before the rule ends. This indicates to the parser that a new section named “Word” is to be added to the AST for the hypothetical language.
Similarly, example rule 650 for “sentence” includes AST nodes 654 and 660 (<ot:Sentence>and </ot:Sentence>) indicating beginning and end for the new AST section for “Sentence.”
XML tree 700 begins with begin-root tag (root) 702 indicating a root for the AST. Next line begins AST node 704 for “Sentence”. Under AST node 704, each word of the example sentence is represented as a child node (e.g. child node 706). Child nodes begin with the begin-node tag (ot) and the rule for the node (Word), include the value to be used with the rule in the child node, and end with end-node tag (/ot). The end of child nodes is indicated with end-node tag for parent node (Sentence). XML tree 800 is terminated with end-root tag (/root).
Example XML markups shown in
The above specification, examples and data provide a complete description of the manufacture and use of the composition of the invention. Since many embodiments of the invention can be made without departing from the spirit and scope of the invention, the invention resides in the claims hereinafter appended.