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.
4855 lines
252 KiB
4855 lines
252 KiB
compUnit
|
|
|-- decl
|
|
| `-- varDecl
|
|
| |-- bType
|
|
| | `-- Int: int
|
|
| |-- varDef
|
|
| | `-- Ident: n
|
|
| `-- Semi: ;
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: bubblesort
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- Ident: arr
|
|
| | |-- L_BRACKET: [
|
|
| | `-- R_BRACKET: ]
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: j
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | |-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: n
|
|
| | | |-- SubOp: -
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: j
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- While: while
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | |-- LtOp: <
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: n
|
|
| | | | | |-- SubOp: -
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- If: if
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- cond
|
|
| | | | | `-- lOrExp
|
|
| | | | | `-- lAndExp
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | |-- relExp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- GtOp: >
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: arr
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | |-- AddOp: +
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 1
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- R_PAREN: )
|
|
| | | | `-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- decl
|
|
| | | | | `-- varDecl
|
|
| | | | | |-- bType
|
|
| | | | | | `-- Int: int
|
|
| | | | | |-- varDef
|
|
| | | | | | `-- Ident: tmp
|
|
| | | | | `-- Semi: ;
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | `-- Ident: tmp
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | |-- addExp
|
|
| | | | | | | | `-- mulExp
|
|
| | | | | | | | `-- unaryExp
|
|
| | | | | | | | `-- primaryExp
|
|
| | | | | | | | `-- lVal
|
|
| | | | | | | | `-- Ident: j
|
|
| | | | | | | |-- AddOp: +
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- number
|
|
| | | | | | | `-- IntConst: 1
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | `-- Semi: ;
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | |-- addExp
|
|
| | | | | | | | `-- mulExp
|
|
| | | | | | | | `-- unaryExp
|
|
| | | | | | | | `-- primaryExp
|
|
| | | | | | | | `-- lVal
|
|
| | | | | | | | `-- Ident: j
|
|
| | | | | | | |-- AddOp: +
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- number
|
|
| | | | | | | `-- IntConst: 1
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | `-- Semi: ;
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: tmp
|
|
| | | | | `-- Semi: ;
|
|
| | | | `-- R_BRACE: }
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- AddOp: +
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: insertsort
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- Ident: a
|
|
| | |-- L_BRACKET: [
|
|
| | `-- R_BRACKET: ]
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- 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
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: temp
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: temp
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: a
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: j
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: j
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- While: while
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | |-- lAndExp
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | |-- relExp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- GtOp: >
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | |-- unaryOp
|
|
| | | | | | `-- SubOp: -
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | |-- AndOp: &&
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: temp
|
|
| | | | |-- LtOp: <
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: a
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | |-- Ident: a
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | |-- AddOp: +
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 1
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: a
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- SubOp: -
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: a
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- AddOp: +
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: temp
|
|
| | | `-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: QuickSort
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Comma: ,
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | `-- Ident: low
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | `-- Ident: high
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- If: if
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: low
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: high
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: i
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: low
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: j
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: j
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: high
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: k
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: k
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: low
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- While: while
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- LtOp: <
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: j
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- While: while
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- cond
|
|
| | | | | `-- lOrExp
|
|
| | | | | `-- lAndExp
|
|
| | | | | |-- lAndExp
|
|
| | | | | | `-- eqExp
|
|
| | | | | | `-- relExp
|
|
| | | | | | |-- relExp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | |-- LtOp: <
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- AndOp: &&
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | |-- relExp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- GtOp: >
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: k
|
|
| | | | | |-- SubOp: -
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 1
|
|
| | | | |-- R_PAREN: )
|
|
| | | | `-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | |-- SubOp: -
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 1
|
|
| | | | | `-- Semi: ;
|
|
| | | | `-- R_BRACE: }
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- If: if
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- cond
|
|
| | | | | `-- lOrExp
|
|
| | | | | `-- lAndExp
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | |-- relExp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | |-- LtOp: <
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | |-- R_PAREN: )
|
|
| | | | `-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | `-- 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
|
|
| | | | |-- While: while
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- cond
|
|
| | | | | `-- lOrExp
|
|
| | | | | `-- lAndExp
|
|
| | | | | |-- lAndExp
|
|
| | | | | | `-- eqExp
|
|
| | | | | | `-- relExp
|
|
| | | | | | |-- relExp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | |-- LtOp: <
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- AndOp: &&
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | |-- relExp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- LtOp: <
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: k
|
|
| | | | |-- R_PAREN: )
|
|
| | | | `-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- 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
|
|
| | | | |-- If: if
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- cond
|
|
| | | | | `-- lOrExp
|
|
| | | | | `-- lAndExp
|
|
| | | | | `-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | |-- relExp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | |-- LtOp: <
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | |-- R_PAREN: )
|
|
| | | | `-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | `-- Semi: ;
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | `-- Ident: j
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: j
|
|
| | | | | | |-- SubOp: -
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 1
|
|
| | | | | `-- Semi: ;
|
|
| | | | `-- R_BRACE: }
|
|
| | | `-- R_BRACE: }
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: k
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: tmp
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: tmp
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: tmp
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: QuickSort
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: arr
|
|
| | | | | |-- Comma: ,
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: low
|
|
| | | | | |-- Comma: ,
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: tmp
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: tmp
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: tmp
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: QuickSort
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: arr
|
|
| | | | | |-- Comma: ,
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: tmp
|
|
| | | | | |-- Comma: ,
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: high
|
|
| | | | `-- R_PAREN: )
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: getMid
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- Ident: arr
|
|
| | |-- L_BRACKET: [
|
|
| | `-- R_BRACKET: ]
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: mid
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- If: if
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | |-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | |-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: n
|
|
| | | | |-- ModOp: %
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 2
|
|
| | | |-- EqOp: ==
|
|
| | | `-- relExp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | |-- R_PAREN: )
|
|
| | |-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: mid
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | |-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: n
|
|
| | | | | |-- DivOp: /
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 2
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- Return: return
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | |-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | |-- L_PAREN: (
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | |-- addExp
|
|
| | | | | | | | `-- mulExp
|
|
| | | | | | | | `-- unaryExp
|
|
| | | | | | | | `-- primaryExp
|
|
| | | | | | | | `-- lVal
|
|
| | | | | | | | |-- Ident: arr
|
|
| | | | | | | | |-- L_BRACKET: [
|
|
| | | | | | | | |-- exp
|
|
| | | | | | | | | `-- addExp
|
|
| | | | | | | | | `-- mulExp
|
|
| | | | | | | | | `-- unaryExp
|
|
| | | | | | | | | `-- primaryExp
|
|
| | | | | | | | | `-- lVal
|
|
| | | | | | | | | `-- Ident: mid
|
|
| | | | | | | | `-- R_BRACKET: ]
|
|
| | | | | | | |-- AddOp: +
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | |-- Ident: arr
|
|
| | | | | | | |-- L_BRACKET: [
|
|
| | | | | | | |-- exp
|
|
| | | | | | | | `-- addExp
|
|
| | | | | | | | |-- addExp
|
|
| | | | | | | | | `-- mulExp
|
|
| | | | | | | | | `-- unaryExp
|
|
| | | | | | | | | `-- primaryExp
|
|
| | | | | | | | | `-- lVal
|
|
| | | | | | | | | `-- Ident: mid
|
|
| | | | | | | | |-- SubOp: -
|
|
| | | | | | | | `-- mulExp
|
|
| | | | | | | | `-- unaryExp
|
|
| | | | | | | | `-- primaryExp
|
|
| | | | | | | | `-- number
|
|
| | | | | | | | `-- IntConst: 1
|
|
| | | | | | | `-- R_BRACKET: ]
|
|
| | | | | | `-- R_PAREN: )
|
|
| | | | | |-- DivOp: /
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 2
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- Else: else
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: mid
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | |-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: n
|
|
| | | | |-- DivOp: /
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 2
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- Return: return
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: mid
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | `-- R_BRACE: }
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: getMost
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- Ident: arr
|
|
| | |-- L_BRACKET: [
|
|
| | `-- R_BRACKET: ]
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: count
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- constExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1000
|
|
| | | `-- R_BRACKET: ]
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1000
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: count
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- 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
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: max
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: number
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: max
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- decl
|
|
| | | `-- varDecl
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- varDef
|
|
| | | | `-- Ident: num
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: num
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: count
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: num
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: count
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: num
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: count
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: num
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- GtOp: >
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: max
|
|
| | | |-- R_PAREN: )
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: max
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: count
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: num
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: number
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: num
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: number
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: revert
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- Ident: arr
|
|
| | |-- L_BRACKET: [
|
|
| | `-- R_BRACKET: ]
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: temp
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: j
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: j
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: j
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: temp
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: temp
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: j
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: j
|
|
| | | | |-- 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: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: arrCopy
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- Ident: src
|
|
| | | |-- L_BRACKET: [
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- Ident: target
|
|
| | |-- L_BRACKET: [
|
|
| | `-- R_BRACKET: ]
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: target
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: src
|
|
| | | | |-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: calSum
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | `-- Ident: stride
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: sum
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: sum
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: sum
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: sum
|
|
| | | | |-- AddOp: +
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | |-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | |-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | |-- ModOp: %
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: stride
|
|
| | | | |-- NeOp: !=
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: stride
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | |-- R_PAREN: )
|
|
| | | |-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 0
|
|
| | | | | `-- Semi: ;
|
|
| | | | `-- R_BRACE: }
|
|
| | | |-- Else: else
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | |-- Ident: arr
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: i
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: sum
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: sum
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- number
|
|
| | | | | `-- IntConst: 0
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
|-- funcDef
|
|
| |-- funcType
|
|
| | `-- Int: int
|
|
| |-- Ident: avgPooling
|
|
| |-- L_PAREN: (
|
|
| |-- funcFParams
|
|
| | |-- funcFParam
|
|
| | | |-- bType
|
|
| | | | `-- Int: int
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Comma: ,
|
|
| | `-- funcFParam
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | `-- Ident: stride
|
|
| |-- R_PAREN: )
|
|
| `-- block
|
|
| |-- L_BRACE: {
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: sum
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: sum
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: lastnum
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | `-- relExp
|
|
| | | | |-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- LtOp: <
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: stride
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | |-- R_PAREN: )
|
|
| | | |-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | `-- Ident: sum
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: sum
|
|
| | | | | | |-- AddOp: +
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | `-- Semi: ;
|
|
| | | | `-- R_BRACE: }
|
|
| | | |-- Else: else
|
|
| | | `-- stmt
|
|
| | | |-- If: if
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- cond
|
|
| | | | `-- lOrExp
|
|
| | | | `-- lAndExp
|
|
| | | | `-- eqExp
|
|
| | | | |-- eqExp
|
|
| | | | | `-- relExp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- EqOp: ==
|
|
| | | | `-- relExp
|
|
| | | | `-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: stride
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | |-- R_PAREN: )
|
|
| | | |-- stmt
|
|
| | | | `-- block
|
|
| | | | |-- L_BRACE: {
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | `-- Ident: lastnum
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- number
|
|
| | | | | | | `-- IntConst: 0
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | `-- Semi: ;
|
|
| | | | |-- blockItem
|
|
| | | | | `-- stmt
|
|
| | | | | |-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- number
|
|
| | | | | | | `-- IntConst: 0
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- Assign: =
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | `-- mulExp
|
|
| | | | | | |-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: sum
|
|
| | | | | | |-- DivOp: /
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: stride
|
|
| | | | | `-- Semi: ;
|
|
| | | | `-- R_BRACE: }
|
|
| | | |-- Else: else
|
|
| | | `-- stmt
|
|
| | | `-- block
|
|
| | | |-- L_BRACE: {
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: sum
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | |-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: sum
|
|
| | | | | | |-- AddOp: +
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | |-- Ident: arr
|
|
| | | | | | |-- L_BRACKET: [
|
|
| | | | | | |-- exp
|
|
| | | | | | | `-- addExp
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: i
|
|
| | | | | | `-- R_BRACKET: ]
|
|
| | | | | |-- SubOp: -
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: lastnum
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | `-- Ident: lastnum
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | |-- Ident: arr
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | |-- addExp
|
|
| | | | | | | | `-- mulExp
|
|
| | | | | | | | `-- unaryExp
|
|
| | | | | | | | `-- primaryExp
|
|
| | | | | | | | `-- lVal
|
|
| | | | | | | | `-- Ident: i
|
|
| | | | | | | |-- SubOp: -
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: stride
|
|
| | | | | | |-- AddOp: +
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 1
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | `-- Semi: ;
|
|
| | | |-- blockItem
|
|
| | | | `-- stmt
|
|
| | | | |-- lVal
|
|
| | | | | |-- Ident: arr
|
|
| | | | | |-- L_BRACKET: [
|
|
| | | | | |-- exp
|
|
| | | | | | `-- addExp
|
|
| | | | | | |-- addExp
|
|
| | | | | | | |-- addExp
|
|
| | | | | | | | `-- mulExp
|
|
| | | | | | | | `-- unaryExp
|
|
| | | | | | | | `-- primaryExp
|
|
| | | | | | | | `-- lVal
|
|
| | | | | | | | `-- Ident: i
|
|
| | | | | | | |-- SubOp: -
|
|
| | | | | | | `-- mulExp
|
|
| | | | | | | `-- unaryExp
|
|
| | | | | | | `-- primaryExp
|
|
| | | | | | | `-- lVal
|
|
| | | | | | | `-- Ident: stride
|
|
| | | | | | |-- AddOp: +
|
|
| | | | | | `-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- number
|
|
| | | | | | `-- IntConst: 1
|
|
| | | | | `-- R_BRACKET: ]
|
|
| | | | |-- Assign: =
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | |-- mulExp
|
|
| | | | | | `-- unaryExp
|
|
| | | | | | `-- primaryExp
|
|
| | | | | | `-- lVal
|
|
| | | | | | `-- Ident: sum
|
|
| | | | | |-- DivOp: /
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: stride
|
|
| | | | `-- Semi: ;
|
|
| | | `-- R_BRACE: }
|
|
| | |-- 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
|
|
| | | |-- addExp
|
|
| | | | |-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: n
|
|
| | | | |-- SubOp: -
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: stride
|
|
| | | |-- AddOp: +
|
|
| | | `-- 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
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- lVal
|
|
| | | `-- Ident: n
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | |-- Ident: arr
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- 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
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- constExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 32
|
|
| | | `-- R_BRACKET: ]
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | |-- Ident: result
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- constExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 32
|
|
| | | `-- R_BRACKET: ]
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 0
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 7
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 1
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 23
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 2
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 89
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 3
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 26
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 4
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 282
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 5
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 254
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 6
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 27
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 7
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 5
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 8
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 83
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 9
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 273
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 10
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 574
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 11
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 905
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 12
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 354
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 13
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 657
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 14
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 935
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 15
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 264
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 16
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 639
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 17
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 459
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 18
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 29
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 19
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 68
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 20
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 929
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 21
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 756
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 22
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 452
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 23
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 279
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 24
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 58
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 25
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 87
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 26
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 96
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 27
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 36
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 28
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 39
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 29
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 28
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 30
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 1
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | |-- Ident: arr
|
|
| | | |-- L_BRACKET: [
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 31
|
|
| | | `-- R_BRACKET: ]
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 290
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: t
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: arrCopy
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: arr
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: revert
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- decl
|
|
| | `-- varDecl
|
|
| | |-- bType
|
|
| | | `-- Int: int
|
|
| | |-- varDef
|
|
| | | `-- Ident: i
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: bubblesort
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: getMid
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: putint
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: getMost
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: putint
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: arrCopy
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: arr
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: bubblesort
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: arrCopy
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: arr
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: insertsort
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: arrCopy
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: arr
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 31
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: QuickSort
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: result
|
|
| | | | |-- Comma: ,
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: arrCopy
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: arr
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: calSum
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: result
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 4
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: arrCopy
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: arr
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: result
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: t
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | |-- Ident: avgPooling
|
|
| | | |-- L_PAREN: (
|
|
| | | |-- funcRParams
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: result
|
|
| | | | |-- Comma: ,
|
|
| | | | `-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- number
|
|
| | | | `-- IntConst: 3
|
|
| | | `-- R_PAREN: )
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- lVal
|
|
| | | `-- Ident: i
|
|
| | |-- Assign: =
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| |-- blockItem
|
|
| | `-- stmt
|
|
| | |-- While: while
|
|
| | |-- L_PAREN: (
|
|
| | |-- cond
|
|
| | | `-- lOrExp
|
|
| | | `-- lAndExp
|
|
| | | `-- eqExp
|
|
| | | `-- relExp
|
|
| | | |-- relExp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | `-- Ident: i
|
|
| | | |-- LtOp: <
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 32
|
|
| | |-- R_PAREN: )
|
|
| | `-- stmt
|
|
| | `-- block
|
|
| | |-- L_BRACE: {
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- lVal
|
|
| | | | `-- Ident: t
|
|
| | | |-- Assign: =
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | `-- primaryExp
|
|
| | | | `-- lVal
|
|
| | | | |-- Ident: result
|
|
| | | | |-- L_BRACKET: [
|
|
| | | | |-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: i
|
|
| | | | `-- R_BRACKET: ]
|
|
| | | `-- Semi: ;
|
|
| | |-- blockItem
|
|
| | | `-- stmt
|
|
| | | |-- exp
|
|
| | | | `-- addExp
|
|
| | | | `-- mulExp
|
|
| | | | `-- unaryExp
|
|
| | | | |-- Ident: putint
|
|
| | | | |-- L_PAREN: (
|
|
| | | | |-- funcRParams
|
|
| | | | | `-- exp
|
|
| | | | | `-- addExp
|
|
| | | | | `-- mulExp
|
|
| | | | | `-- unaryExp
|
|
| | | | | `-- primaryExp
|
|
| | | | | `-- lVal
|
|
| | | | | `-- Ident: t
|
|
| | | | `-- 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
|
|
| | |-- Return: return
|
|
| | |-- exp
|
|
| | | `-- addExp
|
|
| | | `-- mulExp
|
|
| | | `-- unaryExp
|
|
| | | `-- primaryExp
|
|
| | | `-- number
|
|
| | | `-- IntConst: 0
|
|
| | `-- Semi: ;
|
|
| `-- R_BRACE: }
|
|
`-- EOF: <EOF>
|