Safe Haskell | Safe-Inferred |
---|---|
Language | GHC2021 |
This module helps handle operator chains composed of different operators that may have different precedence and fixities.
Synopsis
- data OpTree ty op
- = OpNode ty
- | OpBranches (NonEmpty (OpTree ty op)) [op]
- pattern BinaryOpBranches :: OpTree ty op -> op -> OpTree ty op -> OpTree ty op
- data OpInfo op = OpInfo {}
- opTreeLoc :: HasLoc l => OpTree (GenLocated l a) b -> SrcSpan
- reassociateOpTree :: Choice "debug" -> (op -> Maybe RdrName) -> ModuleFixityMap -> OpTree ty op -> OpTree ty (OpInfo op)
- isHardSplitterOp :: FixityApproximation -> Bool
Documentation
Intermediate representation of operator trees, where a branching is not just a binary branching (with a left node, right node, and operator like in the GHC's AST), but rather a n-ary branching, with n + 1 nodes and n operators (n >= 1).
This representation allows us to put all the operators with the same precedence level as direct siblings in this tree, to better represent the idea of a chain of operators.
OpNode ty | A node which is not an operator application |
OpBranches (NonEmpty (OpTree ty op)) [op] | A subtree of operator application(s); the invariant is: |
Wrapper for an operator, carrying information about its name and fixity.
OpInfo | |
|