Я пишу синтаксический анализатор JavaScript с Happy , и мне нужно сопоставить регулярное выражение. Я не хочу полностью анализировать регулярное выражение, просто сохраните его как строку.
Соответствующая часть моего AST выглядит так:
data PrimaryExpr
-- | Literal integer
= ExpLitInt Integer
-- | Literal strings
| ExpLitStr String
-- | Identifier
| ExpId String
-- | Bracketed expression
| ExpBrackExp Expression
-- | This (current object)
| ExpThis
-- | Regular Expression
| ExpRegex String
-- | Arrays
| ExpArray ArrayLit
-- | Objects
| ExpObject [(PropName, Assignment)]
deriving Show
Это соответствующий счастливый код:
primaryExpr :: { PrimaryExpr }
: LITINT { ExpLitInt $1 }
| LITSTR { ExpLitStr $1 }
| ID { ExpId $1 }
| THIS { ExpThis }
| regex { ExpRegex $1 }
| arrayLit { ExpArray $1 }
| objectLit { ExpObject $1 }
| '(' expression ')' { ExpBrackExp $2 }
Мой вопрос: как мне определить мой regex
нетерминал? Правильно ли такая структура?
regex :: { String }
: '/' whatHere? '/' { $2 }