JPH11249903A - Abstract syntax tree processing method, computer readable storage medium recording abstract syntax tree processing program, computer readable storage medium recording abstract syntax tree data, and abstract syntax tree processing - Google Patents

Abstract syntax tree processing method, computer readable storage medium recording abstract syntax tree processing program, computer readable storage medium recording abstract syntax tree data, and abstract syntax tree processing

Info

Publication number
JPH11249903A
JPH11249903A JP6205598A JP6205598A JPH11249903A JP H11249903 A JPH11249903 A JP H11249903A JP 6205598 A JP6205598 A JP 6205598A JP 6205598 A JP6205598 A JP 6205598A JP H11249903 A JPH11249903 A JP H11249903A
Authority
JP
Japan
Prior art keywords
syntax
literal
processing
node
data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP6205598A
Other languages
Japanese (ja)
Other versions
JP2879099B1 (en
Inventor
Hiroshi Hitosugi
裕志 一杉
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
National Institute of Advanced Industrial Science and Technology AIST
Original Assignee
Agency of Industrial Science and Technology
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Agency of Industrial Science and Technology filed Critical Agency of Industrial Science and Technology
Priority to JP6205598A priority Critical patent/JP2879099B1/en
Application granted granted Critical
Publication of JP2879099B1 publication Critical patent/JP2879099B1/en
Publication of JPH11249903A publication Critical patent/JPH11249903A/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Landscapes

  • Devices For Executing Special Programs (AREA)

Abstract

PROBLEM TO BE SOLVED: To use a source code of the processing as it is regardless of the change of specifications of an inputted programming language. SOLUTION: A tag of an abstract syntax tree an the object of processing is checked to discriminate whether a node is a literal or a syntax (step S01). If it is a literal, the literal tag is checked to perform individually required processings (steps S021 , S022 ,...). However, general processing (steps S02j ) for other literals is performed with respect to the literal requiring no individual processings. If it is a syntax, branching is performed in accordance with the tag, and individually required processings are performed for respective syntax classifications (steps S031 , S032 ...). However, general processing (step S03k ) for other syntax is performed with respect to the syntax requiring no individual processings. In the case of a syntax, the processing is recursively performed from the step S01 with respect to all subtrees which the abstract syntax tree in the middle of processing has (step S04). The end of the tree structure can be discriminated if a node is a literal.

Description

【発明の詳細な説明】DETAILED DESCRIPTION OF THE INVENTION

【0001】[0001]

【発明の属する技術分野】本発明は、抽象構文木処理方
法、抽象構文木処理プログラムを記録したコンピュータ
読み取り可能な記録媒体、抽象構文木データを記録した
コンピュータ読み取り可能な記録媒体、及び、抽象構文
木処理装置に係る。本発明は、特に、コンパイラ、プリ
プロセッサ又はソースコード処理ツール等の各種プログ
ラム言語において、プログラミング言語の言語仕様に依
存しないで抽象構文木を処理する装置、方法及びその処
理プログラムを記録した記録媒体及び抽象構文木のデー
タ構造を記録した記録媒体に関する。
The present invention relates to an abstract syntax tree processing method, a computer readable recording medium on which an abstract syntax tree processing program is recorded, a computer readable recording medium on which abstract syntax tree data is recorded, and an abstract syntax. The present invention relates to a tree processing device. The present invention particularly relates to an apparatus and a method for processing an abstract syntax tree without depending on the language specifications of a programming language in various program languages such as a compiler, a preprocessor or a source code processing tool, a recording medium storing the processing program, and an abstract. The present invention relates to a recording medium that records a data structure of a syntax tree.

【0002】[0002]

【従来の技術】通常、プリプロセッサ、プリティプリン
タなど、プログラムのソースコードに対して何らかの処
理を行なうプログラムは、文字列として入力されたプロ
グラムを構文解析することによって、処理しやすい木構
造のデータ構造に変換する。プリプロセッサによるプロ
グラムのソースコードに対して何らかの機械的変換を施
すプログラムにおいては、一般に、処理の流れは、次の
ようになる。
2. Description of the Related Art Usually, a program such as a preprocessor or a pretty printer, which performs some processing on a program source code, parses a program input as a character string into a tree-structured data structure which is easy to process. Convert. In a program that performs some mechanical conversion on the source code of the program by the preprocessor, the flow of processing is generally as follows.

【0003】図7に、従来のプリプロセッサによる処理
の流れ図を示す。従来のプリプロセッサ200は、字句
解析器1、構文解析器2、処理部3及び出力部4を備え
る。字句解析器1は、文字列を構文解析しやすい形に切
り出し、区切りを入れて処理を行なう部分である。ここ
で、字句解析器1により切り出されたデータを、トーク
ンと呼ぶ。構文解析器2は、トークンの列を受け取り、
処理しやすい木構造を持ったデータ構造に変換する処理
を行なう部分である。このソースコードを木構造で表現
したものを抽象構文木と呼ぶ。処理部3では、この抽象
構文木に対して構造を変換する処理を行なう。さらに、
出力部4は、抽象構文木を再び文字列に戻して出力す
る。なお、プリプロセッサ200の中には、構文解析を
行なわず、文字列やトークン列の段階のデータに対して
処理を行なう単純なものもある。
FIG. 7 shows a flow chart of processing by a conventional preprocessor. The conventional preprocessor 200 includes a lexical analyzer 1, a syntax analyzer 2, a processing unit 3, and an output unit 4. The lexical analyzer 1 is a part that cuts out a character string into a form that is easy to parse and inserts a delimiter to perform processing. Here, the data cut out by the lexical analyzer 1 is called a token. Parser 2 receives the sequence of tokens,
This is a part that performs processing for converting to a data structure having a tree structure that is easy to process. A representation of this source code in a tree structure is called an abstract syntax tree. The processing unit 3 performs a process of converting the structure of the abstract syntax tree. further,
The output unit 4 converts the abstract syntax tree back into a character string and outputs it. It should be noted that some of the preprocessors 200 are simple in that they do not perform a syntax analysis but perform processing on data at the stage of a character string or token string.

【0004】以下に、従来の抽象構文木のフォーマット
の定義およびそれに対する処理の一例を説明する。一般
に、プログラムのソースコードは、「リテラル」と、リ
テラル以外の「構文」からなる。リテラルとは、整数定
数、文字列定数などである。一方、構文とは、 if 文、
while 文、式、関数呼び出しなどである。また、抽象
構文木とは、リテラルおよび構文をノードとして持つ木
構造のデータである。一般に構文は、内部に別のリテラ
ルあるいは構文を含んでいる。抽象構文木では、内部に
サブツリー(サブツリーもまた抽象構文木である)を持
たせることでこれを表現する。従来において、抽象構文
木のノードは、構文およびリテラルの種類ごとに、異な
るデータ構造のノードから構成されていた。例えば、従
来の方法による抽象構文木の、各ノードの典型的なフォ
ーマット定義例は、次のようになる。なお、ここでは簡
単のために lisp 風にS式を用いて表現しているが、C,
Pascal などの他のプログラミング言語でも、同じ内容
を構造体などの機構を使って表現することができる。
[0004] Hereinafter, an example of a conventional definition of an abstract syntax tree format and processing for the format will be described. Generally, the source code of a program is composed of "literals" and "syntax" other than literals. Literals are integer constants, character string constants, and the like. On the other hand, the syntax is an if statement,
while statements, expressions, function calls, etc. The abstract syntax tree is tree-structured data having a literal and a syntax as nodes. In general, a syntax contains another literal or syntax inside. In the abstract syntax tree, this is expressed by having a subtree (the subtree is also an abstract syntax tree) inside. Conventionally, the nodes of the abstract syntax tree have been configured from nodes having different data structures for each type of syntax and literal. For example, a typical format definition example of each node in the abstract syntax tree according to the conventional method is as follows. Here, for the sake of simplicity, the expression is expressed using lisp-style expressions, but C,
In other programming languages, such as Pascal, the same content can be expressed using structures and other mechanisms.

【0005】 整数リテラル : (int <整数>) 文字列リテラル : (string "文字列") 浮動小数点リテラル : (float <浮動小数点数>) 変数名 : (identifier <変数名番号>) if 文 : (if <条件式> <本体1> <本体2または記号 nil> ) (*注:通常のプログラミング言語において は if 文の2つめの本体は省略可能であるた め、 ここでは記号 nil を使って本体2が省略 され たことを表現している。) while 文 : (while <条件式> <本体>) 手続き定義文 : (procedure <返値の型> <手続き名ID> <引数リスト> <定義本体>)Integer literal: (int <integer>) String literal: (string “character string”) Floating point literal: (float <floating point number>) Variable name: (identifier <variable name number>) if statement: ( if <conditional expression> <body 1> <body 2 or symbol nil>) (* Note: In a normal programming language, the second body of an if statement can be omitted, so here the body is written using the symbol nil. 2 is omitted.) While statement: (while <conditional expression> <body>) procedure definition statement: (procedure <return value type> <procedure name ID> <argument list> <definition body >)

【0006】ここで、それぞれのかっこの中の一番目の
要素(int, string, float, ...等)が、ノードの種類
を現わす部分であり、これを「タグ」と呼ぶ。
Here, the first element (int, string, float,...) In each parenthesis is a part representing the type of the node, and is called a “tag”.

【0007】このような抽象構文木のフォーマットを用
いて、入力ソースコードを表現した一例を以下に示す。
これは、「x=0 ならば、"zero"を印刷する。」という
命令である。抽象構文木では、「x」が、変数名番号「1
2」に記憶されている場合である。
An example in which an input source code is expressed using such an abstract syntax tree format is shown below.
This is a command that "if x = 0, print" zero "." In the abstract syntax tree, “x” is replaced by the variable name number “1”.
2 ".

【0008】 [0008]

【0009】ここで、図8に、このときの従来の抽象構
文木の構成図を示す。この例のようなフォーマット定義
の場合、抽象構文木に対する操作は、一般に次のような
形になる。
FIG. 8 shows a configuration diagram of a conventional abstract syntax tree at this time. In the case of a format definition as in this example, an operation on the abstract syntax tree generally takes the following form.

【0010】 抽象構文木 T に対する処理手続きAの定義{ T のタグを見て分岐: "int" の場合 { T を整数リテラルとして処理 } "string" の場合 { T を文字列リテラルとして処理 } ...(省略)... "if" の場合 { T を if 文として処理、サブツリーを再帰的に処理 } "while" の場合 { T を while 文として処理、サブツリーを再帰的に 処 理 } ...(省略)... その他の場合 { エラーメッセージを出力 } }Definition of processing procedure A for abstract syntax tree T {Branch seeing tag of T: For "int" {Process T as integer literal} For "string" {Process T as a string literal}. .. (omitted) ... In the case of "if" {process T as if statement and process subtree recursively} In the case of "while" {process T as while statement and process subtree recursively}. .. (omitted) ... In other cases {Output error message}}

【0011】抽象構文木に対する処理手続きの例とし
て、ソースコード中に if 文が現れる回数を数える手続
きを疑似コードで書くと以下のようになる。
As an example of a processing procedure for an abstract syntax tree, a procedure for counting the number of times an if statement appears in a source code in pseudo code is as follows.

【0012】 初期設定 { カウンタを0にする counter := 0 } 手続き countIf (T){ T のタグの値で分岐: "int" の場合{ 何もしない } "string" の場合{ 何もしない } ...(省略)... "if" の場合{ カウンタを1増やす counter := counter + 1 再帰的に countIf(<条件式>) を呼ぶ 再帰的に countIf(<本体1>) を呼ぶ <本体2> の値に従って分岐: 記号 nil の場合{ 何もしない } サブツリーの場合{ 再帰的に countIf(<本体2>) を呼ぶ } } "while" の場合 { 再帰的に countIf(<条件式>) を呼ぶ 再帰的に countIf(<本体>) を呼ぶ } ...(省略)... }Initial setting {set counter to 0 counter: = 0} procedure countIf (T) {Branch at tag value of T: "int" {do nothing} "string" {do nothing} ... (omitted) ... In case of "if" {Increment counter by 1 counter: = counter + 1 Recursively call countIf (<conditional expression>) Recursively call countIf (<body1>) < Branch according to the value of body2>: For symbol nil {do nothing} For subtree {call countIf (<body2>) recursively}} For "while" {recursively countIf (<conditional expression> ) Call recursively call countIf (<body>)} ... (omitted) ...}

【0013】ここで、言語仕様に次のような構文が追加
されたとする。 repeat 文: (repeat <本体> <条件式>) すると、上記の抽象構文木操作手続きは、次のように変
更しなければならなくなる。すなわち、条件分岐に rep
eat 文の場合の処理を追加する必要がある。
Here, it is assumed that the following syntax is added to the language specification. repeat statement: (repeat <body><conditionalexpression>) Then, the above abstract syntax tree operation procedure must be changed as follows. That is, rep to the conditional branch
It is necessary to add processing for the eat statement.

【0014】 手続き countIf (T){ T のタグの値で分岐: "int" の場合{ 何もしない } "string" の場合{ 何もしない } ...(省略)... "if" の場合{ カウンタを1増やす counter := counter + 1 再帰的に countIf(<条件式>) を呼ぶ 再帰的に countIf(<本体1>) を呼ぶ <本体2> の値に従って分岐: 記号 nil の場合{ 何もしない } サブツリーの場合{ 再帰的に countIf(<本体2>) を呼ぶ } } "while" の場合 { 再帰的に countIf(<条件式>) を呼ぶ 再帰的に countIf(<本体>) を呼ぶ } "repeat" の場合 { 再帰的に countIf(<本体>) を呼ぶ 再帰的に countIf(<条件式>) を呼ぶ } ...(省略)... }Procedure countIf (T) {Branch at tag value of T: "int" {do nothing} "string" {do nothing} ... (omitted) ... of "if" If {increment the counter by 1 counter: = counter + 1 call countIf (<conditional expression>) recursively call countIf (<body1>) recursively Branch according to the value of <body2>: For symbol nil { Do nothing} For subtrees {call countIf (<body2>) recursively}} For "while" {call countIf (<conditional expression>) recursively Recursively call countIf (<body>) Call} In case of "repeat" {call countIf (<body>) recursively call countIf (<conditional expression>) recursively} ... (omitted) ...}

【0015】[0015]

【発明が解決しようとする課題】従来の方法は、入力す
るプログラミング言語の仕様にほとんど変化がない場合
には、特に大きな問題はない。しかしながら、プログラ
ミング言語の文法が頻繁に拡張される場合、従来のよう
にリテラルおよび構文ごとにノードのフォーマットが決
められていると、言語仕様が拡張されるたびに新たな種
類のノードを定義しなければならない。また、それに従
ってその抽象構文木を操作するプログラムもすべて作り
直さなければならないという問題があった。
The conventional method has no particular problem when the specification of the input programming language hardly changes. However, when the grammar of a programming language is frequently expanded, if the format of the node is determined for each literal and syntax as in the past, a new type of node must be defined each time the language specification is expanded. Must. In addition, there is a problem that all programs that operate on the abstract syntax tree must be rewritten accordingly.

【0016】例えば、上述の例では、以下のような定義
が新たに必要となる。
For example, in the above example, the following definition is newly required.

【0017】このように、従来は、新しい構文が追加さ
れるたびに、独自のフォーマットを持ったノードを定義
が追加され、それに伴って、抽象構文木の再帰処理をす
る部分をすべて変更する必要があった。
As described above, conventionally, each time a new syntax is added, a node having a unique format is added, and accordingly, all the parts for performing recursive processing of the abstract syntax tree need to be changed. was there.

【0018】そこで、本発明は、以上の点に鑑み、規定
するフォーマットとその再帰処理方法を採用することに
より、入力するプログラミング言語の仕様に変更があっ
ても(例えば、新たなリテラルや構文が追加されて
も)、その変更が本質的に影響を及ぼさない処理である
限り、ソースコードに処理を施すプログラムを特に変更
しなくても、その処理のソースコードの大部分は変更せ
ずにそのまま利用できるようにすることを目的とする。
In view of the above, the present invention employs a prescribed format and its recursive processing method, so that even if there is a change in the specification of a programming language to be input (for example, a new literal or syntax (Even if it is added), as long as the change has essentially no effect, even if the program that processes the source code is not specifically changed, most of the source code of the process remains unchanged The purpose is to make it available.

【0019】また、本発明は、将来の言語仕様拡張でど
のようなリテラルや構文が追加されるかは全く予測でき
ないような状況においても、基本的なフォーマットを変
更せずに表現できる抽象構文木のデータ構造を提供する
ことを目的とする。また、本発明は、これによって、そ
の抽象構文木に対して操作を施すプログラムは、構文が
拡張されても変更せずに再利用することができるように
することを目的とする。なお、本発明が規定するフォー
マットを用いることによって、おそらく、考えられるほ
とんどのすべてのプログラミング言語のソースコードが
表現できるようにすることを目的とする。
Further, the present invention provides an abstract syntax tree that can be expressed without changing the basic format even in a situation where it is completely unpredictable what kind of literal or syntax will be added in a future language specification extension. The purpose of the present invention is to provide a data structure. It is another object of the present invention to allow a program that operates on the abstract syntax tree to be reused without changing even if the syntax is extended. The purpose of the present invention is to make it possible to represent source codes of almost all conceivable programming languages by using the format defined by the present invention.

【0020】[0020]

【課題を解決するための手段】本発明の第1の解決手段
によると、リテラル又は構文をノードとして有する木構
造のデータを表現した抽象構文木において、前記抽象構
文木に含まれるあるノードが前記リテラルであるか前記
構文であるかを判定するステップと、前記ノードがリテ
ラルの場合、前記リテラルの種類を表すリテラルタグに
基づいて、前記リテラルの種類毎にリテラル用個別処理
が定義されているときは前記リテラル用個別処理を実行
し、前記リテラル用個別処理が定義されていないときは
その他のリテラルに対するリテラル用一般的処理を実行
するステップと、一方、前記ノードが構文の場合、前記
構文の種類毎に構文用個別処理が定義されているときは
前記構文用個別処理を実行し、前記構文用個別処理が定
義されていないときはその他の構文に対する構文用一般
的処理を実行するステップと、処理中の前記構文に含ま
れるすべてのサブツリーについて、ノードがリテラルか
構文かに応じて、対応する前記リテラル用若しくは構文
用個別処理又は前記リテラル用若しくは構文用一般的処
理を再帰的に実行するステップとを備えた抽象構文木処
理方法を提供する。
According to a first solution of the present invention, in an abstract syntax tree expressing data of a tree structure having a literal or a syntax as a node, a node included in the abstract syntax tree is defined as Judging whether it is a literal or the syntax, and, if the node is a literal, based on a literal tag representing the type of the literal, a literal individual process is defined for each type of the literal. Executing the individual processing for literals, and executing general processing for literals for other literals when the individual processing for literals is not defined. On the other hand, when the node is a syntax, the type of the syntax When the individual processing for syntax is defined for each, the individual processing for syntax is executed, and when the individual processing for syntax is not defined. Performing general processing for syntax for other syntaxes, and for all subtrees included in the syntax being processed, depending on whether the node is a literal or syntax, individual processing for the corresponding literal or syntax, or Recursively executing the general processing for the literal or the syntax.

【0021】本発明の第2の解決手段によると、リテラ
ル又は構文をノードとして有する木構造のデータを表現
した抽象構文木において、前記抽象構文木に含まれるあ
るノードが前記リテラルであるか前記構文であるかを判
定するステップと、前記ノードがリテラルの場合、前記
リテラルの種類を表すリテラルタグに基づいて、前記リ
テラルの種類毎にリテラル用個別処理が定義されている
ときは前記リテラル用個別処理を実行し、前記リテラル
用個別処理が定義されていないときはその他のリテラル
に対するリテラル用一般的処理を実行するステップと、
一方、前記ノードが構文の場合、前記構文の種類毎に構
文用個別処理が定義されているときは前記構文用個別処
理を実行し、前記構文用個別処理が定義されていないと
きはその他の構文に対する構文用一般的処理を実行する
ステップと、処理中の前記構文に含まれるすべてのサブ
ツリーについて、ノードがリテラルか構文かに応じて、
対応する前記リテラル用若しくは構文用個別処理又は前
記リテラル用若しくは構文用一般的処理を再帰的に実行
するステップとを備えた抽象構文木処理プログラムを記
録したコンピュータ読み取り可能な記録媒体を提供す
る。
According to a second solution of the present invention, in an abstract syntax tree representing tree-structured data having a literal or a syntax as a node, if a certain node included in the abstract syntax tree is the literal or the syntax And, if the node is a literal, based on a literal tag representing the type of the literal, if the literal individual process is defined for each type of literal, the literal individual process Executing a general process for literals for other literals when the individual process for literals is not defined,
On the other hand, when the node has a syntax, the syntax individual processing is executed when the syntax individual processing is defined for each type of the syntax, and the other syntax is executed when the syntax individual processing is not defined. Performing general processing for the syntax for, and for all subtrees included in the syntax being processed, depending on whether the node is a literal or a syntax,
A step of recursively executing the corresponding literal or syntactic individual processing or the literal or syntactic general processing, provided is a computer-readable recording medium recording an abstract syntax tree processing program.

【0022】本発明の第3の解決手段によると、リテラ
ル又は構文をノードとして有する木構造で表現した抽象
構文木データを記録したコンピュータ読み取り可能な記
録媒体であって、前記ノードがリテラルであることを示
すタグ、前記リテラルの種類を表すリテラルタグ及び前
記リテラルの内容を表すためのリテラル内容の各領域を
含むリテラルデータと、前記ノードが構文であることを
示すタグ及びサブツリー数分のサブツリーリストの各領
域を含む構文データとを備え、前記抽象構文木データを
各ノードについての前記リテラルデータ及び前記構文デ
ータによる木構造で表現し、前記抽象構文木のノード
は、前記タグに基づいて前記リテラルデータであるか前
記構文データであるかが判定され、その判定結果に応じ
て、前記リテラルデータ及び前記構文データ及び前記構
文に含まれるすべてのサブツリーリスト中の前記リテラ
ルデータ並びに前記構文データについて、対応する個別
処理又は一般的処理が再帰的に実行される抽象構文木デ
ータを記録したコンピュータ読み取り可能な記録媒体を
提供する。
According to a third aspect of the present invention, there is provided a computer-readable recording medium recording abstract syntax tree data expressed in a tree structure having a literal or a syntax as a node, wherein the node is a literal. A tag indicating the type of the literal, a literal tag indicating the type of the literal, and literal data including each area of the literal content for expressing the content of the literal, and a tag indicating that the node is a syntax and a subtree list of the number of subtrees. Syntax data including each region, wherein the abstract syntax tree data is represented by a tree structure based on the literal data and the syntax data for each node, and the node of the abstract syntax tree is the literal data based on the tag. Or the syntax data, and according to the result of the determination, the literal data A computer-readable recording of abstract syntax tree data in which corresponding individual processing or general processing is recursively executed for the syntax data, the literal data in all of the subtree lists included in the syntax, and the syntax data. Provide a possible recording medium.

【0023】本発明の第4の解決手段によると、入力ソ
ースコードに基づいてトークン列に解析する字句解析部
と、前記字句解析器により解析された前記トークン列か
ら、前記リテラル又は前記構文をノードとして有する木
構造で表現し、前記ノードがリテラル又は構文であるこ
とを示すタグを含むデータとして表現した抽象構文木に
解析する構文解析部と、前記構文解析器により解析され
た前記抽象構文木の各ノードを、前記タグに基づいて、
前記リテラルデータであるか前記構文データであるかを
判定し、その判定結果に応じて、前記リテラルデータ及
び前記構文データ及び前記構文に含まれるすべてのサブ
ツリーの前記リテラルデータ並びに前記構文データにつ
いて、対応する個別処理又は一般的処理を再帰的に実行
する処理部と、前記処理部により求められた前記抽象構
文木を文字列に変換した出力ソースコードを出力する出
力部とを備えた抽象構文木処理装置を提供する。
According to a fourth solution of the present invention, a lexical analyzer for analyzing a token sequence based on an input source code, and the literal or the syntax is converted to a node from the token sequence analyzed by the lexical analyzer. A syntax analysis unit that parses into an abstract syntax tree expressed as data including a tag indicating that the node is a literal or a syntax, and a syntax analysis unit that parses the abstract syntax tree analyzed by the syntax analyzer Each node, based on the tag,
Determine whether the literal data or the syntax data, according to the determination result, the literal data and the syntax data and the literal data of all subtrees included in the syntax and the syntax data, corresponding Abstract tree processing comprising: a processing unit that recursively executes individual processing or general processing to be performed; and an output unit that outputs an output source code obtained by converting the abstract syntax tree obtained by the processing unit into a character string. Provide equipment.

【0024】[0024]

【発明の実施の形態】(1)各用語に関する説明 本発明の実施の形態を説明するにあたり、まず、以下に
各用語に関しての定義や説明を述べる。
DESCRIPTION OF THE PREFERRED EMBODIMENTS (1) Description of Terms In describing an embodiment of the present invention, first, definitions and explanations of the terms will be given below.

【0025】・抽象構文木(abstract syntax tree)に関
して ほとんどのプログラミング言語は、 if 文、 while 文
などの構文が入れ子になった構造を持っている。コンパ
イラは、単なる文字列であるソースコードを構文解析
し、「抽象構文木」というデータ構造に変換する。「抽
象構文木」は、再帰的な木構造を持ったデータ構造であ
る。(ただし、1パスコンパイラのように、「抽象構文
木」を作らず、構文解析しながら直接コード生成を行な
う場合もある。) ・ノード(node)に関して 抽象構文木は、ノードが再帰的に繰り返される構造を持
つ。
Regarding an abstract syntax tree Most programming languages have a nested syntax such as if statements and while statements. The compiler parses the source code, which is simply a character string, and converts it into a data structure called “abstract syntax tree”. The “abstract syntax tree” is a data structure having a recursive tree structure. (However, in some cases, code generation is performed directly while parsing, without creating an “abstract syntax tree” as in a one-pass compiler.) • Regarding nodes (nodes) In an abstract syntax tree, nodes are recursively repeated. Has a structure that is

【0026】・再帰的構造(recursive structure)に関
して 抽象構文木のように、あるデータ構造の一部に、全体と
同じデータ構造が含まれているものを「再帰的構造」と
呼ぶ。 ・再帰的処理及び再帰呼び出し(recursive call)に関し
て 「再帰的処理及び再帰呼び出し」は、再帰的構造に対す
る処理の方法である。木構造を引数にとる手続きの場
合、サブツリーを引数として再び自分自身を呼び出す形
になる。これを「再帰呼び出し」と呼び、この処理を
「再帰的処理」と呼ぶ。なお、引数のツリーがサブツリ
ーを持たない場合は、それ以上自分自身を呼ばないよう
に書かないといけない。そうしないと無限に自分自身を
呼び出して停止しなくなってしまう。 ・リテラル(literal)に関して 「リテラル」とは、プログラムのソースコード中に現れ
る定数である。例えば123 は、整数リテラル、 "abc"
は、文字列リテラルと呼ばれる。「リテラル」も抽象構
文木のノードの1つだが、サブツリーは持たない。 ・言語構文(language structure)に関して if 文、 while 文などの言語構文を、本文書では単に
「構文」と呼ぶことにする。通常、構文は、抽象構文木
をサブツリーとして持つ。(なお、サブツリーを持たな
いものもある。)
Regarding recursive structure A structure in which a part of a certain data structure includes the same data structure as the whole, such as an abstract syntax tree, is called a "recursive structure". -Regarding recursive processing and recursive call "Recursive processing and recursive call" is a method of processing for a recursive structure. In the case of a procedure that takes a tree structure as an argument, it calls itself again with a subtree as an argument. This is called "recursive call", and this processing is called "recursive processing". If the argument tree does not have a subtree, it must be written not to call itself any more. Otherwise you will endlessly call yourself and stop. -Regarding literals "Literals" are constants that appear in the source code of a program. For example, 123 is an integer literal, "abc"
Is called a string literal. A "literal" is one of the nodes of an abstract syntax tree, but has no subtree.・ Language structure (language structure) Language constructs such as if statements and while statements are simply referred to as “syntax” in this document. Usually, the syntax has an abstract syntax tree as a subtree. (Note that some do not have subtrees.)

【0027】・識別子(identifier)に関して 「識別子」には、変数名、関数名などがある。識別子
も、抽象構文木のノードになる。 ・トークン(token)に関して 「トークン」とは、プログラムを構文解析しやすいよう
に区切ったものである。変数名、数値、キーワード、演
算子、その他の記号などが、それぞれ「トークン」とし
て表される。 ・構文解析器(parser)に関して プログラムのソースコードを処理するには、まず「構文
解析(parse)」を行なう必要がある。入力されたソース
コードの構造を解釈して、抽象構文木という内部表現に
変換する作業を「構文解析」と言い、それを行なうプロ
グラムを「構文解析器」と言う。構文解析器は、トーク
ンの列を抽象構文木に変換する役割を果たす。 ・字句解析器(lexical analyzer)に関して コンパイラの一部である構文解析器は、「字句解析器」
というサブルーチンを呼び出す。「字句解析器」は、プ
ログラムのソースコードから「トークン」をひとつずつ
切り出す役割を果たす。
Regarding identifiers "Identifiers" include variable names and function names. The identifier is also a node of the abstract syntax tree. -Regarding tokens A "token" is a division of a program for easy parsing. Variable names, numerical values, keywords, operators, other symbols, etc. are each represented as "tokens". -Regarding the parser To process the source code of a program, it is necessary to first perform "parse". The task of interpreting the structure of the input source code and converting it into an internal representation called an abstract syntax tree is called "syntax analysis", and the program that performs the task is called a "syntax analyzer". The parser is responsible for converting a sequence of tokens into an abstract syntax tree.・ About lexical analyzer The lexical analyzer which is a part of the compiler is called “lexical analyzer”.
Is called. The “lexical analyzer” plays a role in extracting “tokens” one by one from the program source code.

【0028】・S式(S-expression)に関して 「S式」とは、lisp 言語における list と呼ぶデータ
構造の表現方法。 かっこの中に、要素をならべて表
す。 ・データの表現に関して 構文解析の各段階におけるデータの表現は、例えば以下
のようになる。このデータ列は、「x = 0ならば、'zer
o'を印刷する。」という内容である。 入力文字列: "if (x = 0) begin print('zero') end;" トークン列: "if" "(" "x" "=" "0" "begin" "print" "(" "'zero'" ")" "end" ";" 抽象構文木(S式): (if (equal (identifier 34) (int 0)) (block (print (string "zero"))) nil) (なお、ここでは、識別子34が、x に対応する。)
Regarding S-expression "S-expression" is a method of expressing a data structure called list in the lisp language. Elements are shown in parentheses. -Data representation The data representation at each stage of the syntax analysis is as follows, for example. This data string is' zer
Print o '. It is the content. Input string: "if (x = 0) begin print ('zero') end;" Token string: "if""(""x""=""0""begin""print""(""' zero '"") "" end "";"Abstract syntax tree (S expression): (if (equal (identifier 34) (int 0)) (block (print (string" zero "))) nil) ( Here, the identifier 34 corresponds to x.)

【0029】(2)抽象構文木とその処理 つぎに、抽象構文木のフォーマットの定義について説明
する。図1に、ノードの構造の説明図を示す。抽象構文
木を構成するノードを、以下のような統一的な再帰的デ
ータ構造として定義する。 抽象構文木のノードの定義:ノードは、ノードの種類を
現わすタグを持つものとする。また、ノードは、リテラ
ルか構文かのいずれかであるとする。
(2) Abstract Syntax Tree and Its Processing Next, the definition of the format of the abstract syntax tree will be described. FIG. 1 is an explanatory diagram of the structure of a node. The nodes constituting the abstract syntax tree are defined as a unified recursive data structure as follows. Definition of a node in an abstract syntax tree: A node has a tag indicating a type of the node. It is assumed that a node is either a literal or a syntax.

【0030】図1(a)に示されるように、ノードが
「リテラル」の場合には、(1)タグ、(2)リテラル
の種類を表すリテラルタグ、(3)リテラルの内容を表
す文字列の3つからなるデータ構造をもってノードを表
現する。タグには、ノードがリテラルであることを表す
値を入れる。一方、図1(b)に示されるように、ノー
ドが「構文」の場合には、(1)タグ、(2)サブツリ
ーの数 N 、(3)サブツリーのリスト(木1、木2、木
3、・・・、木N)の3つからなるデータ構造をもってノ
ードを表現する。タグには、構文の種類を表す値を入れ
る。各サブツリーは、本定義によって定義される構造を
持つ抽象構文木である。このように、リテラル又は構文
のいずれにおいても、タグを備える。
As shown in FIG. 1A, when the node is a "literal", (1) a tag, (2) a literal tag indicating the type of the literal, and (3) a character string indicating the content of the literal A node is represented by a data structure consisting of the following three. In the tag, enter a value indicating that the node is a literal. On the other hand, as shown in FIG. 1B, when the node is “syntax”, (1) tag, (2) number of subtrees N, and (3) list of subtrees (tree 1, tree 2, tree
3,..., Tree N) are represented by nodes. The tag contains a value indicating the type of syntax. Each subtree is an abstract syntax tree having a structure defined by this definition. Thus, a tag is provided in either a literal or a syntax.

【0031】また、図2に、本発明による表現を用いた
抽象構文木の説明図を示す。図示のように、抽象構文木
は、一般に、各ノードがツリー状(木構造)に結合され
ている。通常、構文は、構文又はリテラルをサブツリー
として有し、一方、リテラルは、ツリーの終端となる。
本発明が規定するフォーマットによるノードの具体的な
実現方法は、構文解析器2および処理部3を記述するプ
ログラミング言語によって異なる。例えば lisp 言語を
用いる場合は list を使ったS式で、また、 C言語を用
いる場合は構造体と配列を使って実現することができ
る。以下に、具体的な実現方法を述べる。まず、lisp
言語におけるS式を用いて抽象構文木を表現すると、以
下のようになる。
FIG. 2 is an explanatory diagram of an abstract syntax tree using an expression according to the present invention. As illustrated, in the abstract syntax tree, generally, each node is connected in a tree shape (tree structure). Typically, a syntax has a syntax or a literal as a subtree, while a literal is the end of the tree.
The specific method of realizing the node in the format defined by the present invention differs depending on the programming language that describes the parser 2 and the processing unit 3. For example, when using the lisp language, it can be realized by using an expression using list, and when using the C language, it can be realized using structures and arrays. The specific implementation method is described below. First, lisp
Expressing an abstract syntax tree using S expressions in the language is as follows.

【0032】リテラル (literal <リテラルタグ> <リテラルの中身>) 構文 (<タグ> <木1> <木2> <木3> ...)Literal (literal <literal tag> <literal content>) Syntax (<tag> <tree 1> <tree 2> <tree 3> ...)

【0033】ここで、<リテラルの中身> は、このリテ
ラルの情報を文字列にして表現したものである。文字列
の中にどういう情報を入れるかは、リテラルの種類ごと
に異なる。 例: 123 → (literal int "123") "abcde" → (literal string "abcde") -12.34 → (literal float "-12.34")
Here, <literal content> is a representation of this literal information as a character string. What kind of information is included in a character string depends on the type of literal. Example: 123 → (literal int "123") "abcde" → (literal string "abcde") -12.34 → (literal float "-12.34")

【0034】リテラル以外の構文は、構文の種類をあら
わすタグと、その構文の中身をあらわす可変個のサブツ
リーからなる。なお、S式の場合は、サブツリーのリス
トの長さは容易に数えることができるので、例えば図1
(b)において、サブツリーの数Nを数値として保持し
ておく必要はない。
A syntax other than a literal includes a tag indicating a type of the syntax and a variable number of subtrees indicating the contents of the syntax. In the case of the S-expression, the length of the subtree list can be easily counted.
In (b), it is not necessary to hold the number N of subtrees as a numerical value.

【0035】この抽象構文木のフォーマットを用いた表
現の例は以下のようになる。 例: 入力ソースコード: "if (x = 0) begin print('zero') end;" ↓ 抽象構文木: (if (equal (literal identifier "x") (literal int "0")) (print (literal string "zero")))
An example of an expression using the format of the abstract syntax tree is as follows. Example: Input source code: "if (x = 0) begin print ('zero') end;" ↓ Abstract syntax tree: (if (equal (literal identifier "x") (literal int "0")) (print ( literal string "zero")))

【0036】つぎに、抽象構文木に対する再帰的処理に
ついて説明する。図3に、抽象構文木の処理の流れ図を
示す。図中、ステップS01 において、まず処理の対象
となる抽象構文木のタグを調べることによって、それが
リテラルかそれ以外の構文かを判定する。リテラルの場
合は ステップS02 、一方、構文の場合は ステップS0
3 に移る。ステップS02 においては、抽象構文木のノ
ードのリテラルタグを調べ、その中身にしたがって分岐
し、それぞれのリテラルの種類ごとに、個別に必要な処
理(ステップS021、S022、‥‥)を行う。ただし、リ
テラル用個別処理が必要ないリテラルに対しては、「そ
の他のリテラルの処理」を行う場所に分岐し、その他の
リテラルに対する一般的処理(ステップS02j)を行
う。ステップS03 においては、抽象構文木のノードの
タグを調べ、その中身にしたがって分岐し、構文の種類
ごとに個別に必要な処理(ステップS031、S032、‥
‥)を行う。ただし、構文用個別処理が必要ない構文に
対しては、「その他の構文の処理」を行う場所に分岐
し、その他の構文に対する一般的処理(ステップS0
3k)を行う。 ここで、構文の場合は、ステップS04
に移る。ステップS04においては、処理中の抽象構文木
が持つサブツリーすべてに対して、再帰的にステップS
01 から処理を行う。
Next, recursive processing on the abstract syntax tree will be described. FIG. 3 shows a flowchart of the processing of the abstract syntax tree. In the figure, in step S01, the tag of the abstract syntax tree to be processed is first examined to determine whether it is a literal or another syntax. Step S02 for a literal, while Step S0 for a syntax
Move to 3. In step S02, it examines the literal tag nodes of the abstract syntax tree branches in accordance with the contents, for each type of each literal performs necessary separately processing (step S02 1, S02 2, ‥‥) . However, for individual processing is not required literal for literal branches to location where the "processing other literal" performs general processing for other literal (step S02 j). In step S03, the abstract syntax examines the tag tree nodes, branches according to its contents, the required separate process for each type of syntax (step S03 1, S03 2,
‥)I do. However, for a syntax that does not require individual syntax processing, the process branches to a place where “processing of other syntax” is performed, and general processing for other syntax (step S0)
Do 3k ). Here, in the case of the syntax, step S04
Move on to In step S04, all subtrees of the abstract syntax tree being processed are recursively processed in step S04.
Perform processing from 01.

【0037】すなわち、リテラル又は構文のいずれかの
タグの種類によって、同様に、個別処理又はその他の一
般的処理を実行する。サブツリーがさらに抽象構文木を
有する場合は、更にこのさらなる抽象構文木に含まれる
全てのサブツリーに対して、階層的に処理を繰り返し、
抽象構文木の終端まで、同様の処理を実行する。木構造
の終端は、ノードがリテラルである場合に、判断するこ
とができる。図3に示したような抽象構文木に対する再
帰的処理の一般的な流れを、疑似コードで現わすと、以
下のようになる。
That is, individual processing or other general processing is similarly executed depending on the type of tag, either literal or syntax. If the subtree further has an abstract syntax tree, the process is hierarchically repeated for all the subtrees included in the further abstract syntax tree,
The same processing is performed until the end of the abstract syntax tree. The end of the tree structure can be determined if the node is a literal. The general flow of recursive processing for an abstract syntax tree as shown in FIG. 3 is represented by pseudo code as follows.

【0038】 抽象構文木 T に対する処理手続きAの定義{ T のタグを見て分岐: "literal" の場合{ T のリテラルタグを見て分岐 "int" の場合 { T を整数リテラルとして処理 } "string" の場合 { T を文字列リテラルとして処理 } ...(省略)... その他の場合 { その他のリテラルに対する一般的処理 } } その他の場合{ T のタグを見て分岐: "if" の場合 { T を if 文として処理 } "while" の場合 { T を while 文として処理 } ...(省略)... その他の場合 { その他の構文に対する一般的処理 } T の各サブツリーに対して、 再帰的に処理手続きAを呼ぶ } }Definition of processing procedure A for abstract syntax tree T {Branch seeing tag of T: In case of "literal" {Branch seeing literal tag of T In case of "int" {Process T as an integer literal} " string "{process T as a string literal} ... (omitted) ... otherwise {general process for other literals}} otherwise {branch off looking at T tag:" if " In the case of {process T as an if statement} In the case of "while" {process T as a while statement} ... (omitted) ... In other cases {general processing for other syntax} For each subtree of T And recursively call procedure A}}

【0039】再帰呼び出しの停止条件は、ツリーのタグ
が "literal" かどうかだけで決まるため、処理対象の
言語がどのようなリテラルを持つかということには依存
しない。また、構文のサブツリーに対する再帰呼び出し
は、無条件に引数の数だけ再帰呼び出しをするだけでよ
く、構文の種類には依存しない。したがって、将来の言
語仕様拡張で、新たなリテラルや構文が追加された場合
でも、この処理ルーチンは全く変更の必要がない。
Since the condition for stopping the recursive call is determined only by whether the tag of the tree is "literal", it does not depend on what literal the language to be processed has. Also, recursive calls to the subtree of the syntax need only unconditionally make recursive calls for the number of arguments, and do not depend on the type of syntax. Therefore, even if a new literal or syntax is added in a future language specification extension, this processing routine does not need to be changed at all.

【0040】つぎに、抽象構文木に対する処理手続きの
例として、ソースコード中に if 文が現れる回数を数え
る手続き(countIf (T))を疑似コードで書くと以下の
ようになる。
Next, as an example of a processing procedure for the abstract syntax tree, a procedure (countIf (T)) for counting the number of times the if statement appears in the source code will be described as follows.

【0041】 手続き countIf (T){ T のタグを見て分岐: "literal" の場合{ 何もしない } その他の場合 { T のタグが "if" の場合{ counter := counter + 1; } T のサブツリーのすべて(Ti とする)に対して、 再帰的に countIf(Ti) を呼ぶ } }Procedure countIf (T) {Branch seeing tag of T: if "literal" {do nothing} Other cases {if tag of T is "if" {counter: = counter + 1;} T Call countIf (Ti) recursively on all of the subtrees (assuming Ti)}}

【0042】ここで、言語仕様に次のような構文が追加
されたとする。 repeat 文: (repeat <本体> <条件式>) この場合、従来技術では、 repeat 文を処理する部分を
追加する必要があった。しかし上記の手続きの場合、 r
epeat 文に対する処理は、「その他の構文に対する処
理」だけで対処可能なので、一切変更しなくても正しく
動作する。なお、本フォーマットを用いると、 if 文の
else 部ように、省略可能なサブツリーを持つ構文の処
理記述も簡単になる。上述のように、従来の方法による
抽象構文木のフォーマット例の場合、else部が省略され
たかそうでないかによって、場合分けを行なって処理す
る必要があった。しかし、本フォーマットでは、もとも
とサブツリーの数が可変個として扱われているため、そ
のような場合分けの必要はない。つまり、 if 文に els
e 部が指定されている場合はサブツリーの数は2個、el
se部が省略されている場合はサブツリーの数は3個のノ
ードとして表現され、特に場合わけしなくても再帰的処
理が行なえる。
Here, it is assumed that the following syntax is added to the language specification. repeat statement: (repeat <body><conditionalexpression>) In this case, in the prior art, it was necessary to add a part for processing the repeat statement. But for the above procedure, r
Since the processing for the epeat statement can be dealt with only by "processing for other syntaxes", it operates correctly without any changes. Note that if this format is used,
As in the else part, the processing description of a syntax with an optional subtree is also simplified. As described above, in the case of the format example of the abstract syntax tree according to the conventional method, it is necessary to perform processing according to cases depending on whether the else part is omitted or not. However, in this format, the number of sub-trees is originally treated as a variable number, so there is no need to divide such cases. That is, els in the if statement
If the e part is specified, the number of subtrees is 2, and el
When the se part is omitted, the number of subtrees is expressed as three nodes, and recursive processing can be performed without any special case.

【0043】また、処理効率向上等の目的で、あらかじ
め固定個の種類のノードを、特別なフォーマットを持っ
たノードとして定義しておいても、本発明の特長を損な
うことはない。例えば、 X という名前の識別子(変数
名など)を (identifier "X") といったノードで表現する場合を考える。この場合再帰
呼び出しの停止条件の判定は、タグが "literal" かど
うかだけでなく identifier かどうかも調べなければな
らない。この場合、例えば、図3ステップS01の前又
は後に identifier であるかどうかの判断ステップを追
加し、さらに、その処理を追加することにより実行する
ことができる。例えば if文の数を数える処理手順は、
次のようになる。
Further, even if a fixed number of types of nodes are defined in advance as nodes having a special format for the purpose of improving processing efficiency, the features of the present invention are not impaired. For example, consider the case where an identifier (variable name, etc.) named X is represented by a node (identifier "X"). In this case, the condition for stopping the recursive call must be checked not only whether the tag is "literal" but also whether it is an identifier. In this case, for example, it can be executed by adding a step of determining whether or not the identifier is before or after step S01 in FIG. 3 and further adding the processing. For example, the procedure for counting the number of if statements is
It looks like this:

【0044】 [0044]

【0045】しかし、この場合でも、「その他の場合の
処理方法」が定義されているため、将来新たなリテラル
や構文が追加されても、処理プログラムに変更を加える
必要はない。さらに、ツリーの各ノードに、型情報、行
番号情報などの付加情報を格納する場所をあらかじめ設
けても良い。
However, even in this case, since the “processing method in other cases” is defined, it is not necessary to change the processing program even if a new literal or syntax is added in the future. Further, a place for storing additional information such as type information and line number information may be provided in advance at each node of the tree.

【0046】(3)ノードの構造の他の例 つぎに、ノードの構造の他の実施の形態について説明す
る。図4に、 C, Pascal などの言語において、構造体
と配列を用いて抽象構文木を表現する場合のデータ構造
の説明図を示したものである。図4(a)は、リテラ
ル、図4(b)は、構文を表現するデータ構造である。
図4(a)は、タグ、リテラルタグ、リテラルの中身
(内容)へのポインタ、という3つのデータからなる構
造体である。タグとリテラルタグは、それぞれどの種類
のノードであるかがわかるような値(文字列あるいはハ
ッシュ表のエントリ番号など)が入る。リテラルの中身
は、実際には文字列へのポインタにより示される。図4
(b)は、タグ、数値 N 、サブツリー配列へのポイン
タの3つのデータからなる構造体である。タグは、図4
(a)と同様、ノードの種類を区別するための値が入
る。N は、このノードが持つサブツリーの数を入れる。
サブツリー配列へのポインタは、長さ N の配列を指し
ている。このサブツリー配列の各要素は、それぞれがサ
ブツリーを表す構造体へのポインタである。ただし、サ
ブツリー数Nを保持するかわりに、サブツリー配列にデ
ータの終了を示す値を入れることにより、サブツリー数
Nをあとから数えられるようにしてもよい。
(3) Another Example of Node Structure Next, another embodiment of the node structure will be described. FIG. 4 is an explanatory diagram of a data structure when an abstract syntax tree is expressed using structures and arrays in languages such as C and Pascal. FIG. 4A shows a literal structure, and FIG. 4B shows a data structure expressing a syntax.
FIG. 4A shows a structure including three data items: a tag, a literal tag, and a pointer to the content (content) of the literal. Each of the tag and the literal tag has a value (a character string or an entry number of a hash table or the like) that indicates which type of node the node is. The contents of a literal are actually indicated by a pointer to a string. FIG.
(B) is a structure including three data items, a tag, a numerical value N, and a pointer to a subtree array. The tag is shown in FIG.
As in (a), a value for distinguishing the node type is entered. N is the number of subtrees this node has.
The pointer to the subtree array points to an array of length N. Each element of the subtree array is a pointer to a structure that represents a subtree. However, instead of holding the number N of subtrees, the number N of subtrees may be counted later by putting a value indicating the end of data in the subtree array.

【0047】この抽象構文木をJava 言語を用いて表現
する場合は、基本的には C, Pascal言語を用いる場合
と同じである。ただし、構造体の変わりにオブジェクト
を用いることになる。また、サブツリー配列の長さはも
ともと Java 言語処理系が保持しているので、オブジェ
クトのメンバとしてあらためて保持する必要はない。
The case where this abstract syntax tree is expressed using the Java language is basically the same as the case where the C and Pascal languages are used. However, an object is used instead of a structure. Also, since the length of the subtree array is originally held by the Java language processing system, there is no need to hold it again as a member of the object.

【0048】今までの説明ではリテラルを表すノードは
サブツリーを持っていなかったが、リテラルを表すノー
ドに対しても長さ0のサブツリーを持たせ、構文とリテ
ラルのフォーマットを統一することで、再帰的処理をさ
らに簡単にすることができる。図5に、リテラルと構文
のデータ構造の共通部分を増やした場合のノード構造図
を示す。ただしこの図は構造体と配列を用いた場合の図
である。このように、本発明では、先頭の3つのデータ
が、リテラルと構文で統一されるため、処理がより容易
になる。このようなフォーマットを採用した場合、ソー
スコード中に if 文が現れる回数を数える手続きの疑似
コードは、以下のようになる。
In the description so far, a node representing a literal does not have a subtree, but a node representing a literal also has a subtree of length 0, and the syntax and the format of the literal are unified, so that recursion is performed. Target processing can be further simplified. FIG. 5 shows a node structure diagram when the common part of the data structure of the literal and the syntax is increased. However, this figure is a figure in the case of using a structure and an array. As described above, in the present invention, the first three data are unified with the literal and the syntax, so that the processing becomes easier. Using this format, the pseudo code for the procedure that counts the number of times the if statement appears in the source code is as follows.

【0049】 手続き countIf (T){ T のタグが "if" の場合{ counter := counter + 1 } T のサブツリーのすべて(Ti とする)に対して、 再帰的に countIf(Ti) を呼ぶ } T がリテラルかどうかを調べる手順が省略できるため、処理がより簡単になる 。Procedure countIf (T) {If the tag of T is "if" {counter: = counter + 1} Call countIf (Ti) recursively on all of the subtrees of T (let it be Ti)} The process is easier because the step of checking whether T is a literal can be omitted.

【0050】(4)拡張可能プリプロセッサへの応用例 本発明の応用例として、「拡張可能プリプロセッサ」に
ついて説明する。プリプロセッサとは、プログラミング
言語のソースコードを入力とし受け取り、それに対して
なんらかの変換処理を施した後、再びソースコードの形
で出力するプログラムである。この拡張可能プリプロセ
ッサは、プラグインと呼ばれる拡張部品を追加すること
で、Java 言語に新しい構文や機能を追加できる。
(4) Application Example to Extensible Preprocessor As an application example of the present invention, an "extensible preprocessor" will be described. A preprocessor is a program that receives a source code of a programming language as input, performs some conversion processing on the input, and then outputs it again in the form of source code. The extensible preprocessor adds new syntax and features to the Java language by adding extensions called plug-ins.

【0051】図6に、拡張可能プリプロセッサの構成図
を示す。この拡張可能プリプロセッサ100は、字句解
析部10、構文解析部20、処理部30、出力部40を
備える。字句解析部10は、文字列を構文解析しやすい
形に切り出し区切りをつける処理を行う部分であり、入
力ソースコードに基づいてトークン列に解析する。構文
解析部20は、字句解析器により解析されたトークン列
から、リテラル又は構文をノードとして有する木構造で
表現し、ノードがリテラル又は構文であることを示すタ
グを含むデータとして表現した抽象構文木に解析する。
構文解析部20は、文法拡張部品(プラグイン)51〜
53を追加して文法を拡張することによって、新たなリ
テラルタグを持つリテラル又は新たなタグを持つ構文を
含む抽象構文木を生成する機能を有する。
FIG. 6 shows a configuration diagram of the expandable preprocessor. The extensible preprocessor 100 includes a lexical analysis unit 10, a syntax analysis unit 20, a processing unit 30, and an output unit 40. The lexical analyzer 10 is a part that performs a process of cutting out and delimiting a character string into a form that is easy to analyze the syntax, and analyzes the token string based on an input source code. The syntax analysis unit 20 expresses a literal or syntax as a tree structure having nodes as tokens from the token sequence analyzed by the lexical analyzer, and an abstract syntax tree expressed as data including a tag indicating that the node is a literal or syntax. To analyze.
The syntax analysis unit 20 includes grammar extension components (plug-ins) 51 to
By extending the grammar by adding 53, it has a function of generating an abstract syntax tree including a literal having a new literal tag or a syntax having a new tag.

【0052】処理部30は、構文解析部20により解析
された抽象構文木の各ノードを、タグに基づいて、リテ
ラルデータであるか構文データであるかを判定し、その
判定結果に応じて、リテラルデータ及び構文データ及び
構文に含まれるすべてのサブツリーのリテラルデータ並
びに構文データについて、対応する個別処理又は一般的
処理を再帰的に実行する(図3参照)。処理部30は、
他のタグ情報に基づいてリテラルデータ及び構文データ
以外の他のデータ(例えば、上述のidentifierの例を参
照。)であると判定し、判定結果に対応する個別処理を
実行する処理器をさらに備えることができる。プラグイ
ン51〜53によって構文解析部20に変更が加えら
れ、入力ソースコードの文法が拡張されても、その文法
拡張が処理に本質的に影響を与えるものでない限り、処
理部30のプログラムは変更せずにそのまま再利用する
ことができる。出力部40は、処理部30により求めら
れた抽象構文木を再び文字列に変換した出力ソースコー
ドを出力する。
The processing unit 30 determines whether each node of the abstract syntax tree analyzed by the syntax analysis unit 20 is literal data or syntax data based on the tag, and according to the determination result, The corresponding individual processing or general processing is performed recursively on the literal data and the syntax data and the literal data and syntax data of all the subtrees included in the syntax (see FIG. 3). The processing unit 30
The apparatus further includes a processor that determines that the data is other than literal data and syntax data based on other tag information (for example, refer to the above-described example of the identifier) and executes individual processing corresponding to the determination result. be able to. Even if a change is made to the syntax analysis unit 20 by the plug-ins 51 to 53 and the grammar of the input source code is extended, the program of the processing unit 30 is modified unless the grammar extension essentially affects the processing. It can be reused without being used. The output unit 40 outputs an output source code obtained by converting the abstract syntax tree obtained by the processing unit 30 into a character string again.

【0053】[0053]

【発明の効果】以上のように、本発明によると、規定す
るフォーマットとその再帰処理方法を採用することによ
り、入力するプログラミング言語の仕様に変更があって
も(例えば、新たなリテラルや構文が追加されても)、
その変更が本質的に影響を及ぼさない処理である限り、
ソースコードに処理を施すプログラムを特に変更しなく
ても、その処理のソースコードの大部分は変更せずにそ
のまま利用できるようにすることができる。また、本発
明によると、将来の言語仕様拡張でどのようなリテラル
や構文が追加されるかは全く予測できないような状況に
おいても、基本的なフォーマットを変更せずに表現でき
る抽象構文木のデータ構造を提供することができる。ま
た、本発明によると、これによって、その抽象構文木に
対して操作を施すプログラムは、構文が拡張されても変
更せずに再利用することができる。なお、本発明が規定
するフォーマットを用いることによって、おそらく、考
えられるほとんどのすべてのプログラミング言語のソー
スコードを表現することができる。
As described above, according to the present invention, by adopting the prescribed format and its recursive processing method, even if the specification of the input programming language is changed (for example, a new literal or syntax Even if added),
As long as the change has essentially no effect,
Even if the program that performs the processing on the source code is not particularly changed, most of the source code for the processing can be used as it is without being changed. Further, according to the present invention, even in a situation where it is impossible to predict what literals and syntax will be added in future language specification expansion, data of an abstract syntax tree that can be expressed without changing the basic format Structure can be provided. Further, according to the present invention, a program that operates on the abstract syntax tree can be reused without any change even if the syntax is extended. By using the format defined by the present invention, it is possible to express the source code of almost all conceivable programming languages.

【図面の簡単な説明】[Brief description of the drawings]

【図1】ノードの構造の説明図。FIG. 1 is an explanatory diagram of a node structure.

【図2】本発明による表現を用いた抽象構文木の説明
図。
FIG. 2 is an explanatory diagram of an abstract syntax tree using an expression according to the present invention.

【図3】抽象構文木の処理の流れ図。FIG. 3 is a flowchart of processing of an abstract syntax tree.

【図4】構造体と配列を用いて抽象構文木を表現する場
合のデータ構造の説明図。
FIG. 4 is an explanatory diagram of a data structure when an abstract syntax tree is expressed using structures and arrays.

【図5】リテラルと構文のデータ構造の共通部分を増や
した場合のノード構造図。
FIG. 5 is a node structure diagram when a common part of a literal and a syntax data structure is increased.

【図6】拡張可能プリプロセッサの構成図。FIG. 6 is a configuration diagram of an extensible preprocessor.

【図7】従来のプリプロセッサによる処理の流れ図。FIG. 7 is a flowchart of a process performed by a conventional preprocessor.

【図8】従来の抽象構文木の構成図。FIG. 8 is a configuration diagram of a conventional abstract syntax tree.

【符号の説明】[Explanation of symbols]

100 拡張可能プリプロセッサ 10 字句解析部 20 構文解析部 30 処理部 40 出力部 51〜53 プラグイン REFERENCE SIGNS LIST 100 extensible preprocessor 10 lexical analyzer 20 syntax analyzer 30 processor 40 output unit 51-53 plug-in

───────────────────────────────────────────────────── フロントページの続き (54)【発明の名称】 抽象構文木処理方法、抽象構文木処理プログラムを記録したコンピュータ読み取り可能な記録媒 体、抽象構文木データを記録したコンピュータ読み取り可能な記録媒体、及び、抽象構文木処理 装置 ──────────────────────────────────────────────────続 き Continuation of front page (54) [Title of Invention] Abstract syntax tree processing method, computer readable recording medium storing abstract syntax tree processing program, computer readable recording medium storing abstract syntax tree data And abstract syntax tree processing device

Claims (15)

【特許請求の範囲】[Claims] 【請求項1】リテラル又は構文をノードとして有する木
構造のデータを表現した抽象構文木において、前記抽象
構文木に含まれるあるノードが前記リテラルであるか前
記構文であるかを判定するステップと、 前記ノードがリテラルの場合、前記リテラルの種類を表
すリテラルタグに基づいて、前記リテラルの種類毎にリ
テラル用個別処理が定義されているときは前記リテラル
用個別処理を実行し、前記リテラル用個別処理が定義さ
れていないときはその他のリテラルに対するリテラル用
一般的処理を実行するステップと、 一方、前記ノードが構文の場合、前記構文の種類毎に構
文用個別処理が定義されているときは前記構文用個別処
理を実行し、前記構文用個別処理が定義されていないと
きはその他の構文に対する構文用一般的処理を実行する
ステップと、 処理中の前記構文に含まれるすべてのサブツリーについ
て、ノードがリテラルか構文かに応じて、対応する前記
リテラル用若しくは構文用個別処理又は前記リテラル用
若しくは構文用一般的処理を再帰的に実行するステップ
とを備えた抽象構文木処理方法。
1. An abstract syntax tree expressing data of a tree structure having a literal or a syntax as a node, and determining whether a node included in the abstract syntax tree is the literal or the syntax. When the node is a literal, based on a literal tag indicating the type of the literal, when individual processing for a literal is defined for each type of the literal, the individual processing for the literal is executed, and the individual processing for the literal is performed. Executing general processing for literals for other literals when is not defined; and, when the node is a syntax, when individual processing for syntax is defined for each type of syntax, the syntax Execute individual processing for syntax, and execute general processing for syntax for other syntaxes when the individual processing for syntax is not defined. Recursively, for all subtrees included in the syntax being processed, depending on whether the node is a literal or a syntax, the corresponding individual processing for the literal or syntax or the general processing for the literal or syntax recursively. Executing the abstract syntax tree.
【請求項2】前記再帰的に実行するステップは、 木構造を引数にとる手続の場合に、サブツリーを引数と
して再び呼び出して処理を実行することを特徴とする請
求項1に記載の抽象構文木処理方法。
2. The abstract syntax tree according to claim 1, wherein the step of recursively executing, in the case of a procedure taking a tree structure as an argument, executes the process by calling again with a subtree as an argument. Processing method.
【請求項3】前記サブツリーリスト中のノードが、リテ
ラルの場合、前記再帰的に実行するステップの停止条件
とすることを特徴とする請求項1又は2に記載の抽象構
文木処理方法。
3. The abstract syntax tree processing method according to claim 1, wherein when a node in the subtree list is a literal, the condition is a stop condition of the step of recursively executing.
【請求項4】前記リテラルは、 前記ノードがリテラルであることを示すタグ、前記リテ
ラルの種類を表すリテラルタグ及び前記リテラルの内容
を表すためのリテラル内容の各情報を含むことを特徴と
する請求項1乃至3のいずれかに記載の抽象構文木処理
方法。
4. The method according to claim 1, wherein the literal includes information indicating a tag indicating that the node is a literal, a literal tag indicating a type of the literal, and a literal content for indicating the content of the literal. Item 4. The method for processing an abstract syntax tree according to any one of Items 1 to 3.
【請求項5】前記構文は、 前記ノードが構文であることを示すタグ及びサブツリー
数分のサブツリーリストの各情報を含むことを特徴とす
る請求項1乃至4のいずれかに記載の抽象構文木処理方
法。
5. The abstract syntax tree according to claim 1, wherein the syntax includes a tag indicating that the node is a syntax and each information of a subtree list corresponding to the number of subtrees. Processing method.
【請求項6】前記構文は、 前記サブツリー数又は前記サブツリー数を計算できるよ
うな情報をさらに含むことを特徴とする請求項1乃至5
のいずれかに記載の抽象構文木処理方法。
6. The method according to claim 1, wherein the syntax further includes the number of subtrees or information for calculating the number of subtrees.
The abstract syntax tree processing method according to any one of the above.
【請求項7】前記タグは、 前記リテラル又は構文を示す情報の他に、特定の種類の
ノードを示す他のタグ情報をさらに有することを特徴と
する請求項1乃至6のいずれかに記載の抽象構文木処理
方法。
7. The tag according to claim 1, wherein the tag further has other tag information indicating a specific type of node, in addition to the information indicating the literal or the syntax. Abstract syntax tree processing method.
【請求項8】前記リテラル内容又は前記サブツリーリス
トには、 ポインタが記憶され、前記ポインタにより参照された領
域に前記リテラル又は前記構文の内容が記憶されたこと
を特徴とする請求項1乃至7のいずれかに記載の抽象構
文木処理方法。
8. The method according to claim 1, wherein a pointer is stored in said literal content or said subtree list, and said literal or said syntax content is stored in an area referred to by said pointer. An abstract syntax tree processing method according to any of the above.
【請求項9】リテラルの場合、特定領域にリテラルタグ
として特定の数値又は数値でない文字が記憶され、 構文の場合、前記特定領域にサブツリー数として前記特
定の数値以外の個数を示す数値又は文字が記憶され、 前記特定領域を参照することにより、当該ノードが前記
リテラル又は前記構文かが判定されることを特徴とする
請求項1乃至8のいずれかに記載の抽象構文木処理方
法。
9. In the case of a literal, a specific numerical value or a character that is not a numerical value is stored as a literal tag in a specific area. In the case of syntax, a numerical value or a character indicating a number other than the specific numerical value as the number of subtrees is stored in the specific area. The abstract syntax tree processing method according to claim 1, wherein it is determined whether the node is the literal or the syntax by referring to the specific area.
【請求項10】リテラル又は構文をノードとして有する
木構造のデータを表現した抽象構文木において、前記抽
象構文木に含まれるあるノードが前記リテラルであるか
前記構文であるかを判定するステップと、 前記ノードがリテラルの場合、前記リテラルの種類を表
すリテラルタグに基づいて、前記リテラルの種類毎にリ
テラル用個別処理が定義されているときは前記リテラル
用個別処理を実行し、前記リテラル用個別処理が定義さ
れていないときはその他のリテラルに対するリテラル用
一般的処理を実行するステップと、 一方、前記ノードが構文の場合、前記構文の種類毎に構
文用個別処理が定義されているときは前記構文用個別処
理を実行し、前記構文用個別処理が定義されていないと
きはその他の構文に対する構文用一般的処理を実行する
ステップと、 処理中の前記構文に含まれるすべてのサブツリーについ
て、ノードがリテラルか構文かに応じて、対応する前記
リテラル用若しくは構文用個別処理又は前記リテラル用
若しくは構文用一般的処理を再帰的に実行するステップ
とを備えた抽象構文木処理プログラムを記録したコンピ
ュータ読み取り可能な記録媒体。
10. An abstract syntax tree expressing data of a tree structure having a literal or a syntax as a node, and determining whether a node included in the abstract syntax tree is the literal or the syntax. When the node is a literal, based on a literal tag indicating the type of the literal, when individual processing for a literal is defined for each type of the literal, the individual processing for the literal is executed, and the individual processing for the literal is performed. Executing general processing for literals for other literals when is not defined; and, when the node is a syntax, when individual processing for syntax is defined for each type of syntax, the syntax If the individual processing for syntax is not defined, the general processing for syntax for other syntax is executed. And for all subtrees included in the syntax being processed, depending on whether the node is a literal or a syntax, recursively corresponding the literal or syntax specific process or the literal or syntax general process. And a computer-readable recording medium storing an abstract syntax tree processing program.
【請求項11】リテラル又は構文をノードとして有する
木構造で表現した抽象構文木データを記録したコンピュ
ータ読み取り可能な記録媒体であって、 前記ノードがリテラルであることを示すタグ、前記リテ
ラルの種類を表すリテラルタグ及び前記リテラルの内容
を表すためのリテラル内容の各領域を含むリテラルデー
タと、 前記ノードが構文であることを示すタグ及びサブツリー
数分のサブツリーリストの各領域を含む構文データとを
備え、 前記抽象構文木データを各ノードについての前記リテラ
ルデータ及び前記構文データによる木構造で表現し、 前記抽象構文木のノードは、前記タグに基づいて前記リ
テラルデータであるか前記構文データであるかが判定さ
れ、その判定結果に応じて、前記リテラルデータ及び前
記構文データ及び前記構文に含まれるすべてのサブツリ
ーリスト中の前記リテラルデータ並びに前記構文データ
について、対応する個別処理又は一般的処理が再帰的に
実行される抽象構文木データを記録したコンピュータ読
み取り可能な記録媒体。
11. A computer-readable recording medium for recording abstract syntax tree data expressed by a tree structure having a literal or a syntax as a node, wherein a tag indicating that the node is a literal, and a type of the literal. Literal data including a literal tag to represent and a literal content region for representing the content of the literal, and syntax data including a tag indicating that the node is a syntax and each region of a subtree list for the number of subtrees. Expressing the abstract syntax tree data in a tree structure based on the literal data and the syntax data for each node, and determining whether the node of the abstract syntax tree is the literal data or the syntax data based on the tag Is determined, and the literal data, the syntax data, and the A computer-readable recording medium that records abstract syntax tree data in which corresponding individual processing or general processing is recursively executed for the literal data and the syntax data in all subtree lists included in the notation syntax.
【請求項12】前記構文データは、 前記サブツリー数又は前記サブツリー数を計算できるよ
うな情報をさらに含むことを特徴とする請求項11に記
載の抽象構文木データを記録したコンピュータ読み取り
可能な記録媒体。
12. The computer-readable recording medium according to claim 11, wherein the syntax data further includes the number of subtrees or information for calculating the number of subtrees. .
【請求項13】入力ソースコードに基づいてトークン列
に解析する字句解析部と、 前記字句解析器により解析された前記トークン列から、
前記リテラル又は前記構文をノードとして有する木構造
で表現し、前記ノードがリテラル又は構文であることを
示すタグを含むデータとして表現した抽象構文木に解析
する構文解析部と、 前記構文解析器により解析された前記抽象構文木の各ノ
ードを、前記タグに基づいて、前記リテラルデータであ
るか前記構文データであるかを判定し、その判定結果に
応じて、前記リテラルデータ及び前記構文データ及び前
記構文に含まれるすべてのサブツリーの前記リテラルデ
ータ並びに前記構文データについて、対応する個別処理
又は一般的処理を再帰的に実行する処理部と、 前記処理部により求められた前記抽象構文木を文字列に
変換した出力ソースコードを出力する出力部とを備えた
抽象構文木処理装置。
13. A lexical analyzer for analyzing a token sequence based on an input source code; and a token sequence analyzed by the lexical analyzer,
A syntax analyzer that expresses the literal or the syntax as a tree having nodes as nodes and parses the data into an abstract syntax tree expressed as data including a tag indicating that the node is a literal or a syntax; Each node of the abstract syntax tree is determined based on the tag whether it is the literal data or the syntax data, according to the determination result, the literal data and the syntax data and the syntax A processing unit that recursively executes corresponding individual processing or general processing for the literal data and the syntax data of all the subtrees included in the subtree, and converts the abstract syntax tree obtained by the processing unit into a character string An abstract syntax tree processing device comprising: an output unit configured to output a modified output source code.
【請求項14】前記構文解析器は、 前記ノードがリテラル又は構文であるかを示すタグ以外
の特定種類のノードを示す他のタグ情報を判定するため
の解析器をさらに備えたことを特徴とする請求項13に
記載の抽象構文木処理装置。
14. The parser further comprises an analyzer for determining other tag information indicating a specific type of node other than a tag indicating whether the node is a literal or a syntax. 14. The abstract syntax tree processing device according to claim 13, wherein
【請求項15】前記処理部は、 前記他のタグ情報に基づいて、前記リテラルデータ及び
前記構文データ以外の他のデータであると判定し、その
判定結果に対応する個別処理を実行する処理器をさらに
備えたことを特徴とする請求項13又は14に記載の抽
象構文木処理装置。
15. A processor that determines, based on the other tag information, that the data is other than the literal data and the syntax data, and executes an individual process corresponding to the determination result. 15. The abstract syntax tree processing device according to claim 13, further comprising:
JP6205598A 1998-02-26 1998-02-26 Abstract syntax tree processing method, computer readable recording medium recording abstract syntax tree processing program, computer readable recording medium recording abstract syntax tree data, and abstract syntax tree processing device Expired - Lifetime JP2879099B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP6205598A JP2879099B1 (en) 1998-02-26 1998-02-26 Abstract syntax tree processing method, computer readable recording medium recording abstract syntax tree processing program, computer readable recording medium recording abstract syntax tree data, and abstract syntax tree processing device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP6205598A JP2879099B1 (en) 1998-02-26 1998-02-26 Abstract syntax tree processing method, computer readable recording medium recording abstract syntax tree processing program, computer readable recording medium recording abstract syntax tree data, and abstract syntax tree processing device

Publications (2)

Publication Number Publication Date
JP2879099B1 JP2879099B1 (en) 1999-04-05
JPH11249903A true JPH11249903A (en) 1999-09-17

Family

ID=13189090

Family Applications (1)

Application Number Title Priority Date Filing Date
JP6205598A Expired - Lifetime JP2879099B1 (en) 1998-02-26 1998-02-26 Abstract syntax tree processing method, computer readable recording medium recording abstract syntax tree processing program, computer readable recording medium recording abstract syntax tree data, and abstract syntax tree processing device

Country Status (1)

Country Link
JP (1) JP2879099B1 (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6941524B2 (en) 2002-05-24 2005-09-06 International Business Machines Corporation System and method for displaying a recursive relationship between objects in a tree
JP2006154993A (en) * 2004-11-26 2006-06-15 Fujitsu Ltd Web screen creating method, program, and server
WO2011024554A1 (en) * 2009-08-25 2011-03-03 日本電気株式会社 Assembler device, parsing method, and assembler program
JP2014528128A (en) * 2011-10-24 2014-10-23 グーグル インコーポレイテッド Parsed header for compilation
JP2014211729A (en) * 2013-04-18 2014-11-13 株式会社日立製作所 Computer, program, and data generation method

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110704053B (en) * 2019-09-03 2023-05-23 五八有限公司 Style information processing method and device
CN111124414B (en) * 2019-12-02 2024-02-06 东巽科技(北京)有限公司 Abstract grammar tree word-taking method based on operation link
CN111475809B (en) * 2020-04-09 2023-10-20 杭州奇盾信息技术有限公司 Script confusion detection method, script confusion detection device, computer equipment and storage medium
CN116954622B (en) * 2023-09-18 2023-12-15 北京云枢创新软件技术有限公司 Method for associating abstract syntax tree with source code coordinates, electronic device and medium

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6941524B2 (en) 2002-05-24 2005-09-06 International Business Machines Corporation System and method for displaying a recursive relationship between objects in a tree
JP2006154993A (en) * 2004-11-26 2006-06-15 Fujitsu Ltd Web screen creating method, program, and server
WO2011024554A1 (en) * 2009-08-25 2011-03-03 日本電気株式会社 Assembler device, parsing method, and assembler program
JP5413623B2 (en) * 2009-08-25 2014-02-12 日本電気株式会社 Assemble device, syntax analysis method, and assembler program
JP2014528128A (en) * 2011-10-24 2014-10-23 グーグル インコーポレイテッド Parsed header for compilation
JP2014211729A (en) * 2013-04-18 2014-11-13 株式会社日立製作所 Computer, program, and data generation method

Also Published As

Publication number Publication date
JP2879099B1 (en) 1999-04-05

Similar Documents

Publication Publication Date Title
Wirth et al. Compiler construction
US9710243B2 (en) Parser that uses a reflection technique to build a program semantic tree
US5555169A (en) Computer system and method for converting a conversational statement to computer command language
US7958493B2 (en) Type inference system and method
US7496894B2 (en) Methods for enhancing pointer analyses
JPS61103247A (en) Translation program generation system
Scott et al. GLL parse-tree generation
US20030106049A1 (en) Modular parser architecture
EP0735466A2 (en) Method and apparatus for displaying locations of errors detected inside software macro calls
US20030110177A1 (en) Declarative specification and engine for non-isomorphic data mapping
JP2001209547A (en) Source code conversion method, recording medium recording source code conversion programs and source code conversion device
US8850309B2 (en) Optimized methods and devices for the analysis, processing and evaluation of expressions of the XPath type on data of the binary XML type
US20040154009A1 (en) Structuring program code
CN113741869B (en) High-performance variable grammar programming language construction method
US5701490A (en) Method and apparatus for compiler symbol table organization with no lookup in semantic analysis
JP2879099B1 (en) Abstract syntax tree processing method, computer readable recording medium recording abstract syntax tree processing program, computer readable recording medium recording abstract syntax tree data, and abstract syntax tree processing device
EP0520708B1 (en) Method and apparatus for converting high level form abstract syntaxes into an intermediate form
US20080141230A1 (en) Scope-Constrained Specification Of Features In A Programming Language
US20030233640A1 (en) Structuring program code
CN111381828A (en) Method and device for generating syntax tree of code file and electronic equipment
RU2115158C1 (en) Method and device for confident estimation of semantic symbols in syntax analysis when passing forward from left to right
US20030196195A1 (en) Parsing technique to respect textual language syntax and dialects dynamically
KR102614967B1 (en) Automation system and method for extracting intermediate representation based semantics of javascript
JP3418544B2 (en) Automatic test data generator for programs
Johnstone et al. Evaluating GLR parsing algorithms

Legal Events

Date Code Title Description
S533 Written request for registration of change of name

Free format text: JAPANESE INTERMEDIATE CODE: R313533

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

EXPY Cancellation because of completion of term