-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/
-- | Parsing and pretty printing of Python code.
--
-- language-python is a Haskell library for lexical analysis, parsing and
-- pretty printing Python code. It supports versions 2.x and 3.x of
-- Python.
@package language-python
@version 0.3.3
-- | Conversion to/from escaped characters in strings. Note: currently does
-- not support escaped Unicode character names.
--
-- See:
--
--
module Language.Python.Common.StringEscape
-- | Convert escaped sequences of characters into real characters in
-- a normal Python string.
unescapeString :: String -> String
-- | Convert escaped sequences of characters into real characters in
-- a raw Python string. Note: despite their name, Python raw strings do
-- allow a small set of character escapings, namely the single and double
-- quote characters and the line continuation marker.
unescapeRawString :: String -> String
-- | The set of valid octal digits in Python.
octalDigits :: String
-- | The set of valid hex digits in Python.
hexDigits :: String
-- | Convenience class for pretty printing combinators.
module Language.Python.Common.Pretty
-- | All types which can be transformed into a Doc.
class Pretty a
pretty :: Pretty a => a -> Doc
-- | Transform values into strings.
prettyText :: Pretty a => a -> String
-- | Print just the prefix of something
prettyPrefix :: Pretty a => Int -> a -> Doc
-- | Conditionally wrap parentheses around an item.
parensIf :: Pretty a => (a -> Bool) -> a -> Doc
perhaps :: Pretty a => Maybe a -> Doc -> Doc
-- | A list of things separated by commas.
commaList :: Pretty a => [a] -> Doc
instance Pretty a => Pretty (Maybe a)
instance Pretty Bool
instance Pretty Double
instance Pretty Integer
instance Pretty Int
instance Pretty String
-- | Source location information for the Python lexer and parser. This
-- module provides single-point locations and spans, and conversions
-- between them.
module Language.Python.Common.SrcLocation
-- | A location for a syntactic entity from the source code. The location
-- is specified by its filename, and starting row and column.
data SrcLocation
Sloc :: !String -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> SrcLocation
sloc_filename :: SrcLocation -> !String
sloc_row :: SrcLocation -> {-# UNPACK #-} !Int
sloc_column :: SrcLocation -> {-# UNPACK #-} !Int
NoLocation :: SrcLocation
-- | Source location spanning a contiguous section of a file.
data SrcSpan
-- | A span which starts and ends on the same line.
SpanCoLinear :: !String -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> SrcSpan
span_filename :: SrcSpan -> !String
span_row :: SrcSpan -> {-# UNPACK #-} !Int
span_start_column :: SrcSpan -> {-# UNPACK #-} !Int
span_end_column :: SrcSpan -> {-# UNPACK #-} !Int
-- | A span which starts and ends on different lines.
SpanMultiLine :: !String -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> SrcSpan
span_filename :: SrcSpan -> !String
span_start_row :: SrcSpan -> {-# UNPACK #-} !Int
span_start_column :: SrcSpan -> {-# UNPACK #-} !Int
span_end_row :: SrcSpan -> {-# UNPACK #-} !Int
span_end_column :: SrcSpan -> {-# UNPACK #-} !Int
-- | A span which is actually just one point in the file.
SpanPoint :: !String -> {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> SrcSpan
span_filename :: SrcSpan -> !String
span_row :: SrcSpan -> {-# UNPACK #-} !Int
span_column :: SrcSpan -> {-# UNPACK #-} !Int
-- | No span information.
SpanEmpty :: SrcSpan
-- | Types which have a span.
class Span a where getSpan x = SpanEmpty
getSpan :: Span a => a -> SrcSpan
-- | Create a new span which encloses two spanned things.
spanning :: (Span a, Span b) => a -> b -> SrcSpan
-- | Make a span from two locations. Assumption: either the arguments are
-- the same, or the left one preceeds the right one.
mkSrcSpan :: SrcLocation -> SrcLocation -> SrcSpan
-- | Combines two SrcSpan into one that spans at least all the
-- characters within both spans. Assumes the file part is the same
-- in both inputs
combineSrcSpans :: SrcSpan -> SrcSpan -> SrcSpan
-- | Construct the initial source location for a file.
initialSrcLocation :: String -> SrcLocation
-- | Make a point span from the start of a span
spanStartPoint :: SrcSpan -> SrcSpan
-- | Increment the column of a location.
incColumn :: Int -> SrcLocation -> SrcLocation
-- | Decrement the column of a location, only if they are on the same row.
decColumn :: Int -> SrcLocation -> SrcLocation
-- | Increment the line number (row) of a location by one.
incLine :: Int -> SrcLocation -> SrcLocation
-- | Increment the column of a location by one tab stop.
incTab :: SrcLocation -> SrcLocation
-- | Get the column of the end of a span.
endCol :: SrcSpan -> Int
-- | Get the row of the end of a span.
endRow :: SrcSpan -> Int
-- | Get the column of the start of a span.
startCol :: SrcSpan -> Int
-- | Get the row of the start of a span.
startRow :: SrcSpan -> Int
instance Typeable SrcLocation
instance Typeable SrcSpan
instance Eq SrcLocation
instance Ord SrcLocation
instance Show SrcLocation
instance Data SrcLocation
instance Eq SrcSpan
instance Ord SrcSpan
instance Show SrcSpan
instance Data SrcSpan
instance Span SrcLocation
instance Pretty SrcSpan
instance Span SrcSpan
instance (Span a, Span b) => Span (a, b)
instance (Span a, Span b) => Span (Either a b)
instance Span a => Span (Maybe a)
instance Span a => Span [a]
instance Pretty SrcLocation
-- | Lexical tokens for the Python lexer. Contains the superset of tokens
-- from version 2 and version 3 of Python (they are mostly the same).
module Language.Python.Common.Token
-- | Lexical tokens.
data Token
-- | Indentation: increase.
IndentToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Indentation: decrease.
DedentToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Newline.
NewlineToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Line join (backslash at end of line).
LineJoinToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Single line comment.
CommentToken :: !SrcSpan -> !String -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
-- | Identifier.
IdentifierToken :: !SrcSpan -> !String -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
-- | Literal: string.
StringToken :: !SrcSpan -> !String -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
-- | Literal: byte string.
ByteStringToken :: !SrcSpan -> !String -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
-- | Literal: unicode string, version 2 only.
UnicodeStringToken :: !SrcSpan -> !String -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
-- | Literal: integer.
IntegerToken :: !SrcSpan -> !String -> !Integer -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
token_integer :: Token -> !Integer
-- | Literal: long integer. Version 2 only.
LongIntegerToken :: !SrcSpan -> !String -> !Integer -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
token_integer :: Token -> !Integer
-- | Literal: floating point.
FloatToken :: !SrcSpan -> !String -> !Double -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
token_double :: Token -> !Double
-- | Literal: imaginary number.
ImaginaryToken :: !SrcSpan -> !String -> !Double -> Token
token_span :: Token -> !SrcSpan
token_literal :: Token -> !String
token_double :: Token -> !Double
-- | Keyword: 'def'.
DefToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'while'.
WhileToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'if'.
IfToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'True'.
TrueToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'False'.
FalseToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'Return'.
ReturnToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'try'.
TryToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'except'.
ExceptToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'raise'.
RaiseToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'in'.
InToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'is'.
IsToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'lambda'.
LambdaToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'class'.
ClassToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'finally'.
FinallyToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'None'.
NoneToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'for'.
ForToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'from'.
FromToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'global'.
GlobalToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'with'.
WithToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'as'.
AsToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'elif'.
ElifToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'yield'.
YieldToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'assert'.
AssertToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'import'.
ImportToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'pass'.
PassToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'break'.
BreakToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'continue'.
ContinueToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'del'.
DeleteToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'else'.
ElseToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'not'.
NotToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: boolean conjunction 'and'.
AndToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: boolean disjunction 'or'. Version 3.x only:
OrToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'nonlocal' (Python 3.x only) Version 2.x only:
NonLocalToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'print'. (Python 2.x only)
PrintToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Keyword: 'exec'. (Python 2.x only)
ExecToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: at sign '@'.
AtToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: left round bracket '('.
LeftRoundBracketToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: right round bracket ')'.
RightRoundBracketToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: left square bracket '['.
LeftSquareBracketToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: right square bracket ']'.
RightSquareBracketToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: left curly bracket '{'.
LeftBraceToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: right curly bracket '}'.
RightBraceToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: dot (full stop) '.'.
DotToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: comma ','.
CommaToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: semicolon ';'.
SemiColonToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: colon ':'.
ColonToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: ellipses (three dots) '...'.
EllipsisToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: right facing arrow '->'.
RightArrowToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: assignment '='.
AssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: plus assignment '+='.
PlusAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: minus assignment '-='.
MinusAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: multiply assignment '*='
MultAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: divide assignment '/='.
DivAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: modulus assignment '%='.
ModAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: power assignment '**='.
PowAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: binary-and assignment '&='.
BinAndAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: binary-or assignment '|='.
BinOrAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: binary-xor assignment '^='.
BinXorAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: binary-left-shift assignment '<<='.
LeftShiftAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: binary-right-shift assignment '>>='.
RightShiftAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: floor-divide assignment '='.
FloorDivAssignToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Delimiter: back quote character '`\'.
BackQuoteToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: plus '+'.
PlusToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: minus: '-'.
MinusToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: multiply '*'.
MultToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: divide '/'.
DivToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: greater-than '>'.
GreaterThanToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: less-than '<'.
LessThanToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: equals '=='.
EqualityToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: greater-than-or-equals '>='.
GreaterThanEqualsToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: less-than-or-equals '<='.
LessThanEqualsToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: exponential '**'.
ExponentToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: binary-or '|'.
BinaryOrToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: binary-xor '^'.
XorToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: binary-and '&'.
BinaryAndToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: binary-shift-left '<<'.
ShiftLeftToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: binary-shift-right '>>'.
ShiftRightToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: modulus '%'.
ModuloToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: floor-divide ''.
FloorDivToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: tilde '~'.
TildeToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: not-equals '!='.
NotEqualsToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Operator: not-equals ''. Version 2 only.
NotEqualsV2Token :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | End of file
EOFToken :: !SrcSpan -> Token
token_span :: Token -> !SrcSpan
-- | Produce a string from a token containing detailed information. Mainly
-- intended for debugging.
debugTokenString :: Token -> String
-- | Produce a string from a token which is suitable for printing as Python
-- concrete syntax. Invisible tokens yield an empty string.
tokenString :: Token -> String
-- | Test if a token contains its literal source text.
hasLiteral :: Token -> Bool
-- | Classification of tokens
data TokenClass
Comment :: TokenClass
Number :: TokenClass
Identifier :: TokenClass
Punctuation :: TokenClass
Bracket :: TokenClass
Layout :: TokenClass
Keyword :: TokenClass
String :: TokenClass
Operator :: TokenClass
Assignment :: TokenClass
classifyToken :: Token -> TokenClass
instance Typeable Token
instance Eq Token
instance Ord Token
instance Show Token
instance Data Token
instance Show TokenClass
instance Eq TokenClass
instance Ord TokenClass
instance Span Token
-- | Representation of the Python abstract syntax tree (AST). The
-- representation is a superset of versions 2.x and 3.x of Python. In
-- many cases they are identical. The documentation in this module
-- indicates where they are different.
--
-- All the data types have a (polymorphic) parameter which allows the AST
-- to be annotated by an arbitrary type (for example source locations).
-- Specialised instances of the types are provided for source spans. For
-- example Module a is the type of modules, and
-- ModuleSpan is the type of modules annoted with source span
-- information.
--
-- Note: there are cases where the AST is more liberal than the formal
-- grammar of the language. Therefore some care must be taken when
-- constructing Python programs using the raw AST.
module Language.Python.Common.AST
-- | Convenient access to annotations in annotated types.
class Annotated t
annot :: Annotated t => t annot -> annot
-- | A module (Python source file).
--
--
newtype Module annot
-- | A module is just a sequence of top-level statements.
Module :: [Statement annot] -> Module annot
type ModuleSpan = Module SrcSpan
-- | Identifier.
data Ident annot
Ident :: !String -> annot -> Ident annot
ident_string :: Ident annot -> !String
ident_annot :: Ident annot -> annot
type IdentSpan = Ident SrcSpan
-- | A compound name constructed with the dot operator.
type DottedName annot = [Ident annot]
type DottedNameSpan = DottedName SrcSpan
-- | Statements.
--
--
data Statement annot
-- | Import statement.
Import :: [ImportItem annot] -> annot -> Statement annot
-- | Items to import.
import_items :: Statement annot -> [ImportItem annot]
stmt_annot :: Statement annot -> annot
-- | From ... import statement.
FromImport :: ImportRelative annot -> FromItems annot -> annot -> Statement annot
-- | Module to import from.
from_module :: Statement annot -> ImportRelative annot
-- | Items to import.
from_items :: Statement annot -> FromItems annot
stmt_annot :: Statement annot -> annot
-- | While loop.
While :: Expr annot -> Suite annot -> Suite annot -> annot -> Statement annot
-- | Loop condition.
while_cond :: Statement annot -> Expr annot
-- | Loop body.
while_body :: Statement annot -> Suite annot
-- | Else clause.
while_else :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | For loop.
For :: [Expr annot] -> Expr annot -> Suite annot -> Suite annot -> annot -> Statement annot
-- | Loop variables.
for_targets :: Statement annot -> [Expr annot]
-- | Loop generator.
for_generator :: Statement annot -> Expr annot
-- | Loop body
for_body :: Statement annot -> Suite annot
-- | Else clause.
for_else :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | Function definition.
Fun :: Ident annot -> [Parameter annot] -> Maybe (Expr annot) -> Suite annot -> annot -> Statement annot
-- | Function name.
fun_name :: Statement annot -> Ident annot
-- | Function parameter list.
fun_args :: Statement annot -> [Parameter annot]
-- | Optional result annotation.
fun_result_annotation :: Statement annot -> Maybe (Expr annot)
-- | Function body.
fun_body :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | Class definition.
Class :: Ident annot -> [Argument annot] -> Suite annot -> annot -> Statement annot
-- | Class name.
class_name :: Statement annot -> Ident annot
-- | Class argument list. In version 2.x this is only ArgExprs.
class_args :: Statement annot -> [Argument annot]
-- | Class body.
class_body :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | Conditional statement (if-elif-else).
Conditional :: [(Expr annot, Suite annot)] -> Suite annot -> annot -> Statement annot
-- | Sequence of if-elif conditional clauses.
cond_guards :: Statement annot -> [(Expr annot, Suite annot)]
-- | Possibly empty unconditional else clause.
cond_else :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | Assignment statement.
Assign :: [Expr annot] -> Expr annot -> annot -> Statement annot
-- | Entity to assign to.
assign_to :: Statement annot -> [Expr annot]
-- | Expression to evaluate.
assign_expr :: Statement annot -> Expr annot
stmt_annot :: Statement annot -> annot
-- | Augmented assignment statement.
AugmentedAssign :: Expr annot -> AssignOp annot -> Expr annot -> annot -> Statement annot
-- | Entity to assign to.
aug_assign_to :: Statement annot -> Expr annot
-- | Assignment operator (for example '+=').
aug_assign_op :: Statement annot -> AssignOp annot
-- | Expression to evaluate.
aug_assign_expr :: Statement annot -> Expr annot
stmt_annot :: Statement annot -> annot
-- | Decorated definition of a function or class.
Decorated :: [Decorator annot] -> Statement annot -> annot -> Statement annot
-- | Decorators.
decorated_decorators :: Statement annot -> [Decorator annot]
-- | Function or class definition to be decorated.
decorated_def :: Statement annot -> Statement annot
stmt_annot :: Statement annot -> annot
-- | Return statement (may only occur syntactically nested in a function
-- definition).
Return :: Maybe (Expr annot) -> annot -> Statement annot
-- | Optional expression to evaluate and return to caller.
return_expr :: Statement annot -> Maybe (Expr annot)
stmt_annot :: Statement annot -> annot
-- | Try statement (exception handling).
Try :: Suite annot -> [Handler annot] -> Suite annot -> Suite annot -> annot -> Statement annot
-- | Try clause.
try_body :: Statement annot -> Suite annot
-- | Exception handlers.
try_excepts :: Statement annot -> [Handler annot]
-- | Possibly empty else clause, executed if and when control flows off the
-- end of the try clause.
try_else :: Statement annot -> Suite annot
-- | Possibly empty finally clause.
try_finally :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | Raise statement (exception throwing).
Raise :: RaiseExpr annot -> annot -> Statement annot
raise_expr :: Statement annot -> RaiseExpr annot
stmt_annot :: Statement annot -> annot
-- | With statement (context management).
With :: [(Expr annot, Maybe (Expr annot))] -> Suite annot -> annot -> Statement annot
-- | Context expression(s) (yields a context manager).
with_context :: Statement annot -> [(Expr annot, Maybe (Expr annot))]
-- | Suite to be managed.
with_body :: Statement annot -> Suite annot
stmt_annot :: Statement annot -> annot
-- | Pass statement (null operation).
Pass :: annot -> Statement annot
stmt_annot :: Statement annot -> annot
-- | Break statement (may only occur syntactically nested in a for or while
-- loop, but not nested in a function or class definition within that
-- loop).
Break :: annot -> Statement annot
stmt_annot :: Statement annot -> annot
-- | Continue statement (may only occur syntactically nested in a for or
-- while loop, but not nested in a function or class definition or
-- finally clause within that loop).
Continue :: annot -> Statement annot
stmt_annot :: Statement annot -> annot
-- | Del statement (delete).
Delete :: [Expr annot] -> annot -> Statement annot
-- | Items to delete.
del_exprs :: Statement annot -> [Expr annot]
stmt_annot :: Statement annot -> annot
-- | Expression statement.
StmtExpr :: Expr annot -> annot -> Statement annot
stmt_expr :: Statement annot -> Expr annot
stmt_annot :: Statement annot -> annot
-- | Global declaration.
Global :: [Ident annot] -> annot -> Statement annot
-- | Variables declared global in the current block.
global_vars :: Statement annot -> [Ident annot]
stmt_annot :: Statement annot -> annot
-- | Nonlocal declaration. Version 3.x only.
NonLocal :: [Ident annot] -> annot -> Statement annot
-- | Variables declared nonlocal in the current block (their binding comes
-- from bound the nearest enclosing scope).
nonLocal_vars :: Statement annot -> [Ident annot]
stmt_annot :: Statement annot -> annot
-- | Assertion.
Assert :: [Expr annot] -> annot -> Statement annot
-- | Expressions being asserted.
assert_exprs :: Statement annot -> [Expr annot]
stmt_annot :: Statement annot -> annot
-- | Print statement. Version 2 only.
Print :: Bool -> [Expr annot] -> Bool -> annot -> Statement annot
-- | Optional chevron (>>)
print_chevron :: Statement annot -> Bool
-- | Arguments to print
print_exprs :: Statement annot -> [Expr annot]
-- | Does it end in a comma?
print_trailing_comma :: Statement annot -> Bool
stmt_annot :: Statement annot -> annot
-- | Exec statement. Version 2 only.
Exec :: Expr annot -> Maybe (Expr annot, Maybe (Expr annot)) -> annot -> Statement annot
-- | Expression to exec.
exec_expr :: Statement annot -> Expr annot
-- | Global and local environments to evaluate the expression within.
exec_globals_locals :: Statement annot -> Maybe (Expr annot, Maybe (Expr annot))
stmt_annot :: Statement annot -> annot
type StatementSpan = Statement SrcSpan
-- | A block of statements. A suite is a group of statements controlled by
-- a clause, for example, the body of a loop.
--
--
type Suite annot = [Statement annot]
type SuiteSpan = Suite SrcSpan
-- | Formal parameter of function definitions and lambda expressions.
--
--
data Parameter annot
-- | Ordinary named parameter.
Param :: Ident annot -> Maybe (Expr annot) -> Maybe (Expr annot) -> annot -> Parameter annot
-- | Parameter name.
--
-- Parameter name.
--
-- Parameter name.
param_name :: Parameter annot -> Ident annot
-- | Optional annotation.
--
-- Optional annotation.
--
-- Optional annotation.
param_py_annotation :: Parameter annot -> Maybe (Expr annot)
-- | Optional default value.
--
-- Optional default value.
param_default :: Parameter annot -> Maybe (Expr annot)
param_annot :: Parameter annot -> annot
-- | Excess positional parameter (single asterisk before its name in the
-- concrete syntax).
VarArgsPos :: Ident annot -> Maybe (Expr annot) -> annot -> Parameter annot
-- | Parameter name.
--
-- Parameter name.
--
-- Parameter name.
param_name :: Parameter annot -> Ident annot
-- | Optional annotation.
--
-- Optional annotation.
--
-- Optional annotation.
param_py_annotation :: Parameter annot -> Maybe (Expr annot)
param_annot :: Parameter annot -> annot
-- | Excess keyword parameter (double asterisk before its name in the
-- concrete syntax).
VarArgsKeyword :: Ident annot -> Maybe (Expr annot) -> annot -> Parameter annot
-- | Parameter name.
--
-- Parameter name.
--
-- Parameter name.
param_name :: Parameter annot -> Ident annot
-- | Optional annotation.
--
-- Optional annotation.
--
-- Optional annotation.
param_py_annotation :: Parameter annot -> Maybe (Expr annot)
param_annot :: Parameter annot -> annot
-- | Marker for the end of positional parameters (not a parameter itself).
EndPositional :: annot -> Parameter annot
param_annot :: Parameter annot -> annot
-- | Tuple unpack. Version 2 only.
UnPackTuple :: ParamTuple annot -> Maybe (Expr annot) -> annot -> Parameter annot
-- | The tuple to unpack.
param_unpack_tuple :: Parameter annot -> ParamTuple annot
-- | Optional default value.
--
-- Optional default value.
param_default :: Parameter annot -> Maybe (Expr annot)
param_annot :: Parameter annot -> annot
type ParameterSpan = Parameter SrcSpan
-- | Tuple unpack parameter. Version 2 only.
data ParamTuple annot
-- | A variable name.
ParamTupleName :: Ident annot -> annot -> ParamTuple annot
param_tuple_name :: ParamTuple annot -> Ident annot
param_tuple_annot :: ParamTuple annot -> annot
-- | A (possibly nested) tuple parameter.
ParamTuple :: [ParamTuple annot] -> annot -> ParamTuple annot
param_tuple :: ParamTuple annot -> [ParamTuple annot]
param_tuple_annot :: ParamTuple annot -> annot
type ParamTupleSpan = ParamTuple SrcSpan
-- | Decorator.
data Decorator annot
Decorator :: DottedName annot -> [Argument annot] -> annot -> Decorator annot
-- | Decorator name.
decorator_name :: Decorator annot -> DottedName annot
-- | Decorator arguments.
decorator_args :: Decorator annot -> [Argument annot]
decorator_annot :: Decorator annot -> annot
type DecoratorSpan = Decorator SrcSpan
-- | Augmented assignment operators.
data AssignOp annot
-- | '+='
PlusAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '-='
MinusAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '*='
MultAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '/='
DivAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '%='
ModAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '*='
PowAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '&='
BinAndAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '|='
BinOrAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '^='
BinXorAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '<<='
LeftShiftAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '>>='
RightShiftAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
-- | '//='
FloorDivAssign :: annot -> AssignOp annot
assignOp_annot :: AssignOp annot -> annot
type AssignOpSpan = AssignOp SrcSpan
-- | Expressions.
--
--
data Expr annot
-- | Variable.
Var :: Ident annot -> annot -> Expr annot
var_ident :: Expr annot -> Ident annot
expr_annot :: Expr annot -> annot
-- | Literal integer.
Int :: Integer -> String -> annot -> Expr annot
int_value :: Expr annot -> Integer
expr_literal :: Expr annot -> String
expr_annot :: Expr annot -> annot
-- | Long literal integer. Version 2 only.
LongInt :: Integer -> String -> annot -> Expr annot
int_value :: Expr annot -> Integer
expr_literal :: Expr annot -> String
expr_annot :: Expr annot -> annot
-- | Literal floating point number.
Float :: Double -> String -> annot -> Expr annot
float_value :: Expr annot -> Double
expr_literal :: Expr annot -> String
expr_annot :: Expr annot -> annot
-- | Literal imaginary number.
Imaginary :: Double -> String -> annot -> Expr annot
imaginary_value :: Expr annot -> Double
expr_literal :: Expr annot -> String
expr_annot :: Expr annot -> annot
-- | Literal boolean.
Bool :: Bool -> annot -> Expr annot
bool_value :: Expr annot -> Bool
expr_annot :: Expr annot -> annot
-- | Literal 'None' value.
None :: annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Ellipsis '...'.
Ellipsis :: annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Literal byte string.
ByteStrings :: [String] -> annot -> Expr annot
byte_string_strings :: Expr annot -> [String]
expr_annot :: Expr annot -> annot
-- | Literal strings (to be concatentated together).
Strings :: [String] -> annot -> Expr annot
strings_strings :: Expr annot -> [String]
expr_annot :: Expr annot -> annot
-- | Unicode literal strings (to be concatentated together). Version 2
-- only.
UnicodeStrings :: [String] -> annot -> Expr annot
unicodestrings_strings :: Expr annot -> [String]
expr_annot :: Expr annot -> annot
-- | Function call.
Call :: Expr annot -> [Argument annot] -> annot -> Expr annot
-- | Expression yielding a callable object (such as a function).
call_fun :: Expr annot -> Expr annot
-- | Call arguments.
call_args :: Expr annot -> [Argument annot]
expr_annot :: Expr annot -> annot
-- | Subscription, for example 'x [y]'.
Subscript :: Expr annot -> Expr annot -> annot -> Expr annot
subscriptee :: Expr annot -> Expr annot
subscript_expr :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Slicing, for example 'w [x:y:z]'.
SlicedExpr :: Expr annot -> [Slice annot] -> annot -> Expr annot
slicee :: Expr annot -> Expr annot
slices :: Expr annot -> [Slice annot]
expr_annot :: Expr annot -> annot
-- | Conditional expresison.
CondExpr :: Expr annot -> Expr annot -> Expr annot -> annot -> Expr annot
-- | Expression to evaluate if condition is True.
ce_true_branch :: Expr annot -> Expr annot
-- | Boolean condition.
ce_condition :: Expr annot -> Expr annot
-- | Expression to evaluate if condition is False.
ce_false_branch :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Binary operator application.
BinaryOp :: Op annot -> Expr annot -> Expr annot -> annot -> Expr annot
operator :: Expr annot -> Op annot
left_op_arg :: Expr annot -> Expr annot
right_op_arg :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Unary operator application.
UnaryOp :: Op annot -> Expr annot -> annot -> Expr annot
operator :: Expr annot -> Op annot
op_arg :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Anonymous function definition (lambda).
Lambda :: [Parameter annot] -> Expr annot -> annot -> Expr annot
lambda_args :: Expr annot -> [Parameter annot]
lambda_body :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Tuple. Can be empty.
Tuple :: [Expr annot] -> annot -> Expr annot
tuple_exprs :: Expr annot -> [Expr annot]
expr_annot :: Expr annot -> annot
-- | Generator yield.
Yield :: Maybe (Expr annot) -> annot -> Expr annot
-- | Optional expression to yield.
yield_expr :: Expr annot -> Maybe (Expr annot)
expr_annot :: Expr annot -> annot
-- | Generator.
Generator :: Comprehension (Expr annot) annot -> annot -> Expr annot
gen_comprehension :: Expr annot -> Comprehension (Expr annot) annot
expr_annot :: Expr annot -> annot
-- | List comprehension.
ListComp :: Comprehension (Expr annot) annot -> annot -> Expr annot
list_comprehension :: Expr annot -> Comprehension (Expr annot) annot
expr_annot :: Expr annot -> annot
-- | List.
List :: [Expr annot] -> annot -> Expr annot
list_exprs :: Expr annot -> [Expr annot]
expr_annot :: Expr annot -> annot
-- | Dictionary.
Dictionary :: [(Expr annot, Expr annot)] -> annot -> Expr annot
dict_mappings :: Expr annot -> [(Expr annot, Expr annot)]
expr_annot :: Expr annot -> annot
-- | Dictionary comprehension. Version 3 only.
DictComp :: Comprehension (Expr annot, Expr annot) annot -> annot -> Expr annot
dict_comprehension :: Expr annot -> Comprehension (Expr annot, Expr annot) annot
expr_annot :: Expr annot -> annot
-- | Set.
Set :: [Expr annot] -> annot -> Expr annot
set_exprs :: Expr annot -> [Expr annot]
expr_annot :: Expr annot -> annot
-- | Set comprehension. Version 3 only.
SetComp :: Comprehension (Expr annot) annot -> annot -> Expr annot
set_comprehension :: Expr annot -> Comprehension (Expr annot) annot
expr_annot :: Expr annot -> annot
-- | Starred expression. Version 3 only.
Starred :: Expr annot -> annot -> Expr annot
starred_expr :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | Parenthesised expression.
Paren :: Expr annot -> annot -> Expr annot
paren_expr :: Expr annot -> Expr annot
expr_annot :: Expr annot -> annot
-- | String conversion (backquoted expression). Version 2 only.
StringConversion :: Expr annot -> annot -> Expr annot
backquoted_expr :: Expr annot -> Expr annot
expr_anot :: Expr annot -> annot
type ExprSpan = Expr SrcSpan
-- | Operators.
data Op annot
-- | 'and'
And :: annot -> Op annot
op_annot :: Op annot -> annot
-- | 'or'
Or :: annot -> Op annot
op_annot :: Op annot -> annot
-- | 'not'
Not :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '**'
Exponent :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '<'
LessThan :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '>'
GreaterThan :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '=='
Equality :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '>='
GreaterThanEquals :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '<='
LessThanEquals :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '!='
NotEquals :: annot -> Op annot
op_annot :: Op annot -> annot
-- | ''. Version 2 only.
NotEqualsV2 :: annot -> Op annot
op_annot :: Op annot -> annot
-- | 'in'
In :: annot -> Op annot
op_annot :: Op annot -> annot
-- | 'is'
Is :: annot -> Op annot
op_annot :: Op annot -> annot
-- | 'is not'
IsNot :: annot -> Op annot
op_annot :: Op annot -> annot
-- | 'not in'
NotIn :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '|'
BinaryOr :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '^'
Xor :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '&'
BinaryAnd :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '<<'
ShiftLeft :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '>>'
ShiftRight :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '*'
Multiply :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '+'
Plus :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '-'
Minus :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '/'
Divide :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '//'
FloorDivide :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '~' (bitwise inversion of its integer argument)
Invert :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '%'
Modulo :: annot -> Op annot
op_annot :: Op annot -> annot
-- | '.'
Dot :: annot -> Op annot
op_annot :: Op annot -> annot
type OpSpan = Op SrcSpan
-- | Arguments to function calls, class declarations and decorators.
data Argument annot
-- | Ordinary argument expression.
ArgExpr :: Expr annot -> annot -> Argument annot
-- | Argument expression.
arg_expr :: Argument annot -> Expr annot
arg_annot :: Argument annot -> annot
-- | Excess positional argument.
ArgVarArgsPos :: Expr annot -> annot -> Argument annot
-- | Argument expression.
arg_expr :: Argument annot -> Expr annot
arg_annot :: Argument annot -> annot
-- | Excess keyword argument.
ArgVarArgsKeyword :: Expr annot -> annot -> Argument annot
-- | Argument expression.
arg_expr :: Argument annot -> Expr annot
arg_annot :: Argument annot -> annot
-- | Keyword argument.
ArgKeyword :: Ident annot -> Expr annot -> annot -> Argument annot
-- | Keyword name.
arg_keyword :: Argument annot -> Ident annot
-- | Argument expression.
arg_expr :: Argument annot -> Expr annot
arg_annot :: Argument annot -> annot
type ArgumentSpan = Argument SrcSpan
-- | Slice compenent.
data Slice annot
SliceProper :: Maybe (Expr annot) -> Maybe (Expr annot) -> Maybe (Maybe (Expr annot)) -> annot -> Slice annot
slice_lower :: Slice annot -> Maybe (Expr annot)
slice_upper :: Slice annot -> Maybe (Expr annot)
slice_stride :: Slice annot -> Maybe (Maybe (Expr annot))
slice_annot :: Slice annot -> annot
SliceExpr :: Expr annot -> annot -> Slice annot
slice_expr :: Slice annot -> Expr annot
slice_annot :: Slice annot -> annot
SliceEllipsis :: annot -> Slice annot
slice_annot :: Slice annot -> annot
type SliceSpan = Slice SrcSpan
-- | An entity imported using the 'import' keyword.
--
--
data ImportItem annot
ImportItem :: DottedName annot -> Maybe (Ident annot) -> annot -> ImportItem annot
-- | The name of module to import.
import_item_name :: ImportItem annot -> DottedName annot
-- | An optional name to refer to the entity (the 'as' name).
import_as_name :: ImportItem annot -> Maybe (Ident annot)
import_item_annot :: ImportItem annot -> annot
type ImportItemSpan = ImportItem SrcSpan
-- | An entity imported using the 'from ... import' construct.
--
--
data FromItem annot
FromItem :: Ident annot -> Maybe (Ident annot) -> annot -> FromItem annot
-- | The name of the entity imported.
from_item_name :: FromItem annot -> Ident annot
-- | An optional name to refer to the entity (the 'as' name).
from_as_name :: FromItem annot -> Maybe (Ident annot)
from_item_annot :: FromItem annot -> annot
type FromItemSpan = FromItem SrcSpan
-- | Items imported using the 'from ... import' construct.
data FromItems annot
-- | Import everything exported from the module.
ImportEverything :: annot -> FromItems annot
from_items_annot :: FromItems annot -> annot
-- | Import a specific list of items from the module.
FromItems :: [FromItem annot] -> annot -> FromItems annot
from_items_items :: FromItems annot -> [FromItem annot]
from_items_annot :: FromItems annot -> annot
type FromItemsSpan = FromItems SrcSpan
-- | A reference to the module to import from using the 'from ... import'
-- construct.
data ImportRelative annot
ImportRelative :: Int -> Maybe (DottedName annot) -> annot -> ImportRelative annot
import_relative_dots :: ImportRelative annot -> Int
import_relative_module :: ImportRelative annot -> Maybe (DottedName annot)
import_relative_annot :: ImportRelative annot -> annot
type ImportRelativeSpan = ImportRelative SrcSpan
-- | Exception handler.
data Handler annot
Handler :: ExceptClause annot -> Suite annot -> annot -> Handler annot
handler_clause :: Handler annot -> ExceptClause annot
handler_suite :: Handler annot -> Suite annot
handler_annot :: Handler annot -> annot
type HandlerSpan = Handler SrcSpan
-- | Exception clause.
data ExceptClause annot
ExceptClause :: Maybe (Expr annot, Maybe (Expr annot)) -> annot -> ExceptClause annot
except_clause :: ExceptClause annot -> Maybe (Expr annot, Maybe (Expr annot))
except_clause_annot :: ExceptClause annot -> annot
type ExceptClauseSpan = ExceptClause SrcSpan
-- | The argument for a raise statement.
data RaiseExpr annot
-- | Optional expression to evaluate, and optional 'from' clause.
-- Version 3 only.
RaiseV3 :: (Maybe (Expr annot, Maybe (Expr annot))) -> RaiseExpr annot
-- | Version 2 only.
RaiseV2 :: (Maybe (Expr annot, Maybe (Expr annot, Maybe (Expr annot)))) -> RaiseExpr annot
type RaiseExprSpan = RaiseExpr SrcSpan
-- | Comprehension. In version 3.x this can be used for lists, sets,
-- dictionaries and generators.
data Comprehension e annot
Comprehension :: e -> CompFor annot -> annot -> Comprehension e annot
comprehension_expr :: Comprehension e annot -> e
comprehension_for :: Comprehension e annot -> CompFor annot
comprehension_annot :: Comprehension e annot -> annot
type ComprehensionSpan e = Comprehension e SrcSpan
-- | Comprehension 'for' component.
data CompFor annot
CompFor :: [Expr annot] -> Expr annot -> Maybe (CompIter annot) -> annot -> CompFor annot
comp_for_exprs :: CompFor annot -> [Expr annot]
comp_in_expr :: CompFor annot -> Expr annot
comp_for_iter :: CompFor annot -> Maybe (CompIter annot)
comp_for_annot :: CompFor annot -> annot
type CompForSpan = CompFor SrcSpan
-- | Comprehension guard.
data CompIf annot
CompIf :: Expr annot -> Maybe (CompIter annot) -> annot -> CompIf annot
comp_if :: CompIf annot -> Expr annot
comp_if_iter :: CompIf annot -> Maybe (CompIter annot)
comp_if_annot :: CompIf annot -> annot
type CompIfSpan = CompIf SrcSpan
-- | Comprehension iterator (either a 'for' or an 'if').
data CompIter annot
IterFor :: CompFor annot -> annot -> CompIter annot
comp_iter_for :: CompIter annot -> CompFor annot
comp_iter_annot :: CompIter annot -> annot
IterIf :: CompIf annot -> annot -> CompIter annot
comp_iter_if :: CompIter annot -> CompIf annot
comp_iter_annot :: CompIter annot -> annot
type CompIterSpan = CompIter SrcSpan
instance Typeable1 Ident
instance Typeable1 ImportItem
instance Typeable1 FromItem
instance Typeable1 FromItems
instance Typeable1 ImportRelative
instance Typeable1 ParamTuple
instance Typeable1 Op
instance Typeable1 Expr
instance Typeable1 Slice
instance Typeable2 Comprehension
instance Typeable1 CompFor
instance Typeable1 CompIter
instance Typeable1 CompIf
instance Typeable1 Argument
instance Typeable1 Parameter
instance Typeable1 ExceptClause
instance Typeable1 Decorator
instance Typeable1 RaiseExpr
instance Typeable1 AssignOp
instance Typeable1 Statement
instance Typeable1 Handler
instance Typeable1 Module
instance Eq annot => Eq (Ident annot)
instance Ord annot => Ord (Ident annot)
instance Show annot => Show (Ident annot)
instance Data annot => Data (Ident annot)
instance Eq annot => Eq (ImportItem annot)
instance Ord annot => Ord (ImportItem annot)
instance Show annot => Show (ImportItem annot)
instance Data annot => Data (ImportItem annot)
instance Eq annot => Eq (FromItem annot)
instance Ord annot => Ord (FromItem annot)
instance Show annot => Show (FromItem annot)
instance Data annot => Data (FromItem annot)
instance Eq annot => Eq (FromItems annot)
instance Ord annot => Ord (FromItems annot)
instance Show annot => Show (FromItems annot)
instance Data annot => Data (FromItems annot)
instance Eq annot => Eq (ImportRelative annot)
instance Ord annot => Ord (ImportRelative annot)
instance Show annot => Show (ImportRelative annot)
instance Data annot => Data (ImportRelative annot)
instance Eq annot => Eq (ParamTuple annot)
instance Ord annot => Ord (ParamTuple annot)
instance Show annot => Show (ParamTuple annot)
instance Data annot => Data (ParamTuple annot)
instance Eq annot => Eq (Op annot)
instance Ord annot => Ord (Op annot)
instance Show annot => Show (Op annot)
instance Data annot => Data (Op annot)
instance Eq annot => Eq (Expr annot)
instance Ord annot => Ord (Expr annot)
instance Show annot => Show (Expr annot)
instance Data annot => Data (Expr annot)
instance Eq annot => Eq (Slice annot)
instance Ord annot => Ord (Slice annot)
instance Show annot => Show (Slice annot)
instance Data annot => Data (Slice annot)
instance (Eq e, Eq annot) => Eq (Comprehension e annot)
instance (Ord e, Ord annot) => Ord (Comprehension e annot)
instance (Show e, Show annot) => Show (Comprehension e annot)
instance (Data e, Data annot) => Data (Comprehension e annot)
instance Eq annot => Eq (CompFor annot)
instance Ord annot => Ord (CompFor annot)
instance Show annot => Show (CompFor annot)
instance Data annot => Data (CompFor annot)
instance Eq annot => Eq (CompIter annot)
instance Ord annot => Ord (CompIter annot)
instance Show annot => Show (CompIter annot)
instance Data annot => Data (CompIter annot)
instance Eq annot => Eq (CompIf annot)
instance Ord annot => Ord (CompIf annot)
instance Show annot => Show (CompIf annot)
instance Data annot => Data (CompIf annot)
instance Eq annot => Eq (Argument annot)
instance Ord annot => Ord (Argument annot)
instance Show annot => Show (Argument annot)
instance Data annot => Data (Argument annot)
instance Eq annot => Eq (Parameter annot)
instance Ord annot => Ord (Parameter annot)
instance Show annot => Show (Parameter annot)
instance Data annot => Data (Parameter annot)
instance Eq annot => Eq (ExceptClause annot)
instance Ord annot => Ord (ExceptClause annot)
instance Show annot => Show (ExceptClause annot)
instance Data annot => Data (ExceptClause annot)
instance Eq annot => Eq (Decorator annot)
instance Ord annot => Ord (Decorator annot)
instance Show annot => Show (Decorator annot)
instance Data annot => Data (Decorator annot)
instance Eq annot => Eq (RaiseExpr annot)
instance Ord annot => Ord (RaiseExpr annot)
instance Show annot => Show (RaiseExpr annot)
instance Data annot => Data (RaiseExpr annot)
instance Eq annot => Eq (AssignOp annot)
instance Ord annot => Ord (AssignOp annot)
instance Show annot => Show (AssignOp annot)
instance Data annot => Data (AssignOp annot)
instance Eq annot => Eq (Statement annot)
instance Ord annot => Ord (Statement annot)
instance Show annot => Show (Statement annot)
instance Data annot => Data (Statement annot)
instance Eq annot => Eq (Handler annot)
instance Ord annot => Ord (Handler annot)
instance Show annot => Show (Handler annot)
instance Data annot => Data (Handler annot)
instance Eq annot => Eq (Module annot)
instance Ord annot => Ord (Module annot)
instance Show annot => Show (Module annot)
instance Data annot => Data (Module annot)
instance Annotated AssignOp
instance Span AssignOpSpan
instance Annotated Op
instance Span OpSpan
instance Annotated Slice
instance Span SliceSpan
instance Annotated Expr
instance Span ExprSpan
instance Annotated CompIter
instance Span CompIterSpan
instance Annotated CompIf
instance Span CompIfSpan
instance Annotated CompFor
instance Span CompForSpan
instance Annotated (Comprehension e)
instance Span (ComprehensionSpan e)
instance Annotated ExceptClause
instance Span ExceptClauseSpan
instance Annotated Handler
instance Span HandlerSpan
instance Annotated Argument
instance Span ArgumentSpan
instance Annotated ParamTuple
instance Span ParamTupleSpan
instance Annotated Parameter
instance Span ParameterSpan
instance Annotated Decorator
instance Span DecoratorSpan
instance Annotated Statement
instance Span StatementSpan
instance Annotated ImportRelative
instance Span ImportRelativeSpan
instance Annotated FromItems
instance Span FromItemsSpan
instance Annotated FromItem
instance Span FromItemSpan
instance Annotated ImportItem
instance Span ImportItemSpan
instance Annotated Ident
instance Span IdentSpan
-- | Pretty printing of the Python abstract syntax (version 2.x and 3.x).
module Language.Python.Common.PrettyAST
instance Pretty (AssignOp a)
instance Pretty (Op a)
instance Pretty (Slice a)
instance Pretty (Expr a)
instance Pretty (CompIter a)
instance Pretty (CompIf a)
instance Pretty (CompFor a)
instance Pretty t => Pretty (Comprehension t a)
instance Pretty (Argument a)
instance Pretty (ParamTuple a)
instance Pretty (Parameter a)
instance Pretty (Decorator a)
instance Pretty (RaiseExpr a)
instance Pretty (ExceptClause a)
instance Pretty (Handler a)
instance Pretty (Statement a)
instance Pretty (ImportRelative a)
instance Pretty (FromItems a)
instance Pretty (FromItem a)
instance Pretty (ImportItem a)
instance Pretty (Ident a)
instance Pretty (Module a)
-- | Pretty printing of tokens. Note the output is intended for displaying
-- in messages to the user, and may not be valid Python syntax. For
-- instance the pretty printing is useful for displaying parser error
-- messages, but not useful for producing concrete Python source.
module Language.Python.Common.PrettyToken
instance Pretty Token
-- | Error values for the lexer and parser.
module Language.Python.Common.ParseError
data ParseError
-- | An error from the parser. Token found where it should not be. Note:
-- tokens contain their own source span.
UnexpectedToken :: Token -> ParseError
-- | An error from the lexer. Character found where it should not be.
UnexpectedChar :: Char -> SrcLocation -> ParseError
-- | A generic error containing a string message. No source location.
StrError :: String -> ParseError
instance Eq ParseError
instance Ord ParseError
instance Show ParseError
instance Error ParseError
-- | Pretty printing of parse errors.
module Language.Python.Common.PrettyParseError
instance Pretty ParseError
-- | Monad support for Python parser and lexer.
module Language.Python.Common.ParserMonad
type P a = StateT ParseState (Either ParseError) a
execParser :: P a -> ParseState -> Either ParseError a
execParserKeepComments :: P a -> ParseState -> Either ParseError (a, [Token])
runParser :: P a -> ParseState -> Either ParseError (a, ParseState)
thenP :: P a -> (a -> P b) -> P b
returnP :: a -> P a
setLocation :: SrcLocation -> P ()
getLocation :: P SrcLocation
getInput :: P String
setInput :: String -> P ()
getLastToken :: P Token
setLastToken :: Token -> P ()
setLastEOL :: SrcSpan -> P ()
getLastEOL :: P SrcSpan
data ParseError
-- | An error from the parser. Token found where it should not be. Note:
-- tokens contain their own source span.
UnexpectedToken :: Token -> ParseError
-- | An error from the lexer. Character found where it should not be.
UnexpectedChar :: Char -> SrcLocation -> ParseError
-- | A generic error containing a string message. No source location.
StrError :: String -> ParseError
data ParseState
ParseState :: !SrcLocation -> !String -> !Token -> [Int] -> [Int] -> [Token] -> !SrcSpan -> [Token] -> ParseState
location :: ParseState -> !SrcLocation
input :: ParseState -> !String
previousToken :: ParseState -> !Token
startCodeStack :: ParseState -> [Int]
indentStack :: ParseState -> [Int]
parenStack :: ParseState -> [Token]
lastEOL :: ParseState -> !SrcSpan
comments :: ParseState -> [Token]
initialState :: SrcLocation -> String -> [Int] -> ParseState
pushStartCode :: Int -> P ()
popStartCode :: P ()
getStartCode :: P Int
getIndent :: P Int
pushIndent :: Int -> P ()
popIndent :: P ()
getIndentStackDepth :: P Int
getParen :: P (Maybe Token)
pushParen :: Token -> P ()
popParen :: P ()
getParenStackDepth :: P Int
addComment :: Token -> P ()
getComments :: P [Token]
spanError :: Span a => a -> String -> P b
instance Show ParseState
-- | Lexical analysis for Python version 3.x programs. See:
-- http://www.python.org/doc/3.1/reference/lexical_analysis.html.
module Language.Python.Version3.Lexer
-- | Parse a string into a list of Python Tokens, or return an error.
lex :: String -> String -> Either ParseError [Token]
-- | Try to lex the first token in an input string. Return either a parse
-- error or a pair containing the next token and the rest of the input
-- after the token.
lexOneToken :: String -> String -> Either ParseError (Token, String)
-- | Lex a sequence of tokens.
lexer :: P [Token]
initLexState :: String -> String -> ParseState
-- | A parser for Python version 3.x programs. Parsers are provided for
-- modules, statements, and expressions. The parsers produce comment
-- tokens in addition to the abstract syntax tree.
--
-- See:
--
--
module Language.Python.Version3.Parser
-- | Parse a whole Python source file. Return comments in addition to the
-- parsed module.
parseModule :: String -> String -> Either ParseError (ModuleSpan, [Token])
-- | Parse one compound statement, or a sequence of simple statements.
-- Generally used for interactive input, such as from the command line of
-- an interpreter. Return comments in addition to the parsed statements.
parseStmt :: String -> String -> Either ParseError ([StatementSpan], [Token])
-- | Parse an expression. Generally used as input for the 'eval' primitive.
-- Return comments in addition to the parsed expression.
parseExpr :: String -> String -> Either ParseError (ExprSpan, [Token])
-- | A convenient re-export of the parser and lexer for version 3.x of
-- Python.
--
-- See:
--
--
module Language.Python.Version3
-- | Lexical analysis for Python version 2.x programs. See:
-- http://www.python.org/doc/2.6/reference/lexical_analysis.html.
module Language.Python.Version2.Lexer
-- | Parse a string into a list of Python Tokens, or return an error.
lex :: String -> String -> Either ParseError [Token]
-- | Try to lex the first token in an input string. Return either a parse
-- error or a pair containing the next token and the rest of the input
-- after the token.
lexOneToken :: String -> String -> Either ParseError (Token, String)
-- | A parser for Python version 2.x programs. Parsers are provided for
-- modules, statements, and expressions. The parsers produce comment
-- tokens in addition to the abstract syntax tree.
--
-- See:
--
--
module Language.Python.Version2.Parser
-- | Parse a whole Python source file. Return comments in addition to the
-- parsed module.
parseModule :: String -> String -> Either ParseError (ModuleSpan, [Token])
-- | Parse one compound statement, or a sequence of simple statements.
-- Generally used for interactive input, such as from the command line of
-- an interpreter. Return comments in addition to the parsed statements.
parseStmt :: String -> String -> Either ParseError ([StatementSpan], [Token])
-- | Parse an expression. Generally used as input for the 'eval' primitive.
-- Return comments in addition to the parsed expression.
parseExpr :: String -> String -> Either ParseError (ExprSpan, [Token])
-- | A convenient re-export of the parser and lexer for version 2.x of
-- Python.
--
-- See:
--
--
module Language.Python.Version2
-- | Convenient re-export of common code, which works with both version 2.x
-- and 3.x of Python.
module Language.Python.Common