forked from NUDT-compiler/nudt-compiler-cpp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1875 lines
97 KiB
1875 lines
97 KiB
compUnit
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: quick_read
|
|
| |-- L_PAREN: (
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: ch
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: getch
|
|
| | | |-- L_PAREN: (
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: x
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | |-- Comma: ,
|
|
| | |-- varDef
|
|
| | | |-- Ident: f
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | |-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: ch
|
|
| | | | |-- LtOp: <
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 48
|
|
| | | |-- OrOp: ||
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: ch
|
|
| | | |-- GtOp: >
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 57
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | |-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: ch
|
|
| | | | |-- EqOp: ==
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 45
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: f
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: ch
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: getch
|
|
| | | | |-- L_PAREN: (
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | |-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: ch
|
|
| | | | |-- GeOp: >=
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 48
|
|
| | | |-- AndOp: &&
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: ch
|
|
| | | |-- LeOp: <=
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 57
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | |-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: x
|
|
| | | | | | |-- MulOp: *
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 10
|
|
| | | | | |-- AddOp: +
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: ch
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 48
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: ch
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: getch
|
|
| | | | |-- L_PAREN: (
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- If: if
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: f
|
|
| | |-- R_PAREN: )
|
|
| | |-- stmt
|
|
| | | |-- Return: return
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- unaryOp
|
|
| | | | | `-- SubOp: -
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | `-- Semi: ;
|
|
| | |-- Else: else
|
|
| | `-- stmt
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: x
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- decl
|
|
| `-- constDecl
|
|
| |-- Const: const
|
|
| |-- bType
|
|
| | `-- Int: int
|
|
| |-- constDef
|
|
| | |-- Ident: maxn
|
|
| | |-- Assign: =
|
|
| | `-- constInitVal
|
|
| | `-- constExp
|
|
| | `-- addExp
|
|
| | `-- mulExp
|
|
| | `-- unaryExp
|
|
| | `-- primaryExp
|
|
| | `-- number
|
|
| | `-- IntConst: 10005
|
|
| `-- Semi: ;
|
|
|-- decl
|
|
| `-- varDecl
|
|
| |-- bType
|
|
| | `-- Int: int
|
|
| |-- varDef
|
|
| | `-- Ident: n
|
|
| |-- Comma: ,
|
|
| |-- varDef
|
|
| | `-- Ident: m
|
|
| |-- Comma: ,
|
|
| |-- varDef
|
|
| | |-- Ident: f
|
|
| | |-- L_BRACKET: [
|
|
| | |-- constExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: maxn
|
|
| | |-- R_BRACKET: ]
|
|
| | |-- L_BRACKET: [
|
|
| | |-- constExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 20
|
|
| | `-- R_BRACKET: ]
|
|
| |-- Comma: ,
|
|
| |-- varDef
|
|
| | |-- Ident: dep
|
|
| | |-- L_BRACKET: [
|
|
| | |-- constExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: maxn
|
|
| | `-- R_BRACKET: ]
|
|
| `-- Semi: ;
|
|
|-- decl
|
|
| `-- varDecl
|
|
| |-- bType
|
|
| | `-- Int: int
|
|
| |-- varDef
|
|
| | |-- Ident: to
|
|
| | |-- L_BRACKET: [
|
|
| | |-- constExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: maxn
|
|
| | `-- R_BRACKET: ]
|
|
| |-- Comma: ,
|
|
| |-- varDef
|
|
| | |-- Ident: next
|
|
| | |-- L_BRACKET: [
|
|
| | |-- constExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: maxn
|
|
| | `-- R_BRACKET: ]
|
|
| |-- Comma: ,
|
|
| |-- varDef
|
|
| | |-- Ident: head
|
|
| | |-- L_BRACKET: [
|
|
| | |-- constExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: maxn
|
|
| | `-- R_BRACKET: ]
|
|
| |-- Comma: ,
|
|
| |-- varDef
|
|
| | |-- Ident: cnt
|
|
| | |-- Assign: =
|
|
| | `-- initVal
|
|
| | `-- exp
|
|
| | `-- addExp
|
|
| | `-- mulExp
|
|
| | `-- unaryExp
|
|
| | `-- primaryExp
|
|
| | `-- number
|
|
| | `-- IntConst: 0
|
|
| `-- Semi: ;
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Void: void
|
|
| |-- Ident: add_edge
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | `-- Ident: from
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | `-- Ident: To
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: to
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: cnt
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: To
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: next
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: cnt
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | |-- Ident: head
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: from
|
|
| | | `-- R_BRACKET: ]
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: head
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: from
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: cnt
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: cnt
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | |-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: cnt
|
|
| | | |-- AddOp: +
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: f
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: To
|
|
| | | |-- R_BRACKET: ]
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: from
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Void: void
|
|
| |-- Ident: init
|
|
| |-- L_PAREN: (
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: dep
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0x3f3f3f3f
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LeOp: <=
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: head
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- unaryOp
|
|
| | | | | `-- SubOp: -
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Void: void
|
|
| |-- Ident: tree
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | `-- Ident: x
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | `-- Ident: d
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: dep
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: d
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | |-- Ident: f
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | |-- R_BRACKET: ]
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: f
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: x
|
|
| | | | |-- R_BRACKET: ]
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | |-- AddOp: +
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: f
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: f
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: x
|
|
| | | | | |-- R_BRACKET: ]
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- R_BRACKET: ]
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | |-- Ident: head
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | `-- R_BRACKET: ]
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | |-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- NeOp: !=
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- unaryOp
|
|
| | | | `-- SubOp: -
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | |-- Ident: y
|
|
| | | | |-- Assign: =
|
|
| | | | `-- initVal
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: to
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: tree
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: y
|
|
| | | | | |-- Comma: ,
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: d
|
|
| | | | | |-- AddOp: +
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: next
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: LCA
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | `-- Ident: x
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | `-- Ident: y
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- If: if
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: dep
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: x
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | |-- Ident: dep
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: y
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | |-- Ident: t
|
|
| | | | |-- Assign: =
|
|
| | | | `-- initVal
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: y
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: y
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 19
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: dep
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: x
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- GtOp: >
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | |-- Ident: dep
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: y
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | |-- lAndExp
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: f
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: x
|
|
| | | | | |-- R_BRACKET: ]
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- AndOp: &&
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: dep
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: f
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: x
|
|
| | | | | | |-- R_BRACKET: ]
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- GeOp: >=
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: dep
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: y
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: f
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: x
|
|
| | | | |-- R_BRACKET: ]
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- If: if
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | |-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | |-- EqOp: ==
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: y
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: x
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 19
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- GeOp: >=
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | |-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: f
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: x
|
|
| | | | | |-- R_BRACKET: ]
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- NeOp: !=
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: f
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: y
|
|
| | | | |-- R_BRACKET: ]
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: x
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: f
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: x
|
|
| | | | | |-- R_BRACKET: ]
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: y
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: f
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: y
|
|
| | | | | |-- R_BRACKET: ]
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | |-- Ident: f
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: x
|
|
| | | |-- R_BRACKET: ]
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- R_BRACKET: ]
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: main
|
|
| |-- L_PAREN: (
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: quick_read
|
|
| | | |-- L_PAREN: (
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: m
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: quick_read
|
|
| | | |-- L_PAREN: (
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: init
|
|
| | | |-- L_PAREN: (
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | `-- initVal
|
|
| | | `-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | |-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- NeOp: !=
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | |-- Ident: x
|
|
| | | | |-- Assign: =
|
|
| | | | `-- initVal
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: quick_read
|
|
| | | | |-- L_PAREN: (
|
|
| | | | `-- R_PAREN: )
|
|
| | | |-- Comma: ,
|
|
| | | |-- varDef
|
|
| | | | |-- Ident: y
|
|
| | | | |-- Assign: =
|
|
| | | | `-- initVal
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: quick_read
|
|
| | | | |-- L_PAREN: (
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: add_edge
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: x
|
|
| | | | | |-- Comma: ,
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: y
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: tree
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: m
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | |-- Ident: x
|
|
| | | | |-- Assign: =
|
|
| | | | `-- initVal
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: quick_read
|
|
| | | | |-- L_PAREN: (
|
|
| | | | `-- R_PAREN: )
|
|
| | | |-- Comma: ,
|
|
| | | |-- varDef
|
|
| | | | |-- Ident: y
|
|
| | | | |-- Assign: =
|
|
| | | | `-- initVal
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: quick_read
|
|
| | | | |-- L_PAREN: (
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | |-- Ident: LCA
|
|
| | | | | |-- L_PAREN: (
|
|
| | | | | |-- funcRParams
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: x
|
|
| | | | | | |-- Comma: ,
|
|
| | | | | | `-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: y
|
|
| | | | | `-- R_PAREN: )
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putch
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 10
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: m
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: m
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
`-- EOF: <EOF>
|