! [      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCD E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                   ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                   ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                   ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                           !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~Safedl fortran-src5Convert a Fortran literal Real into a Haskell Double. fortran-src9Convert a Fortran literal Integer into a Haskell Integer.Safe 8=>?@ACUVdSafe 8=>?@ACUVeSafe278>it& fortran-src.line-offset and filename as given by a pragma.+ fortran-srcE(line, column) number taking into account any specified line pragmas., fortran-src<Path of file taking into account any specified line pragmas. !&%$#"'()*+,-./0'( !&%$#")*+,-./0Safe 27>@ACXjH?@ABCDEFGJIHKMLNOSRQPTUZYXWV[`_^]\abdcemihlkjgfnopqrstuvwxyz{|}~Hemihlkjgfnoabdc[`_^]\TUZYXWVNOSRQPpKMLFGJIHqrsDEABCtuvwxyz{|}~?@Safe27pp fortran-srcJObtain set of intrinsics that are most closely aligned with given version. fortran-srcmname => (return-unit, parameter-units) This is an exhaustive list of intrinsics listed in 15.10 of X3.9-1978None 27=>?@AFqvfedc_^]\[ZYXWVUTSRQPONMLIHFEDCBA@?>=;98653210.-,*)(&$#"!    /<b  KJG+'a`:74%ghjiklmnosrqptuwvxyz{|~}      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~|~}xyz{nosrqptuwvmklghjifedc_^]\[ZYXWVUTSRQPONMLIHFEDCBA@?>=;98653210.-,*)(&$#"!    /<b  KJG+'a`:74%      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~None 27=>?@AF}+01 ,- "#$%&'()*    /.!23456}3456+01 ,- "#$%&'()*    /.!2 None 2478=>?@A2v fortran-src/The string representation of an integer literalw fortran-src+The string representation of a real literalx fortran-src/The real and imaginary parts of a complex valuey fortran-srcA string literalz fortran-srcA Hollerith literal{ fortran-srcThe name of a variable| fortran-srcThe name of a built-in function} fortran-srcA boolean value~ fortran-src$User-defined operators in interfaces fortran-src#Overloaded assignment in interfaces fortran-srcUse a value as an expression. fortran-src-A binary operator applied to two expressions. fortran-src,A unary operator applied to two expressions. fortran-srcArray indexing fortran-src%) notation for variables inside data types fortran-src5A function expression applied to a list of arguments. fortran-src$Implied do (i.e. one-liner do loops) fortran-srcArray initialisation fortran-src#Function return value specification^ fortran-srcspecified with a *_ fortran-srcPspecified with a : (Fortran2003) FIXME, possibly, with a more robust const-exp:` fortran-src'specified with a non-trivial expressiona fortran-src!specified with a constant integeri fortran-srclen and kind, if specifiedFDEFGKJIHLMNQPORSTWVUXjihgfedb`^]\[ZY_cakomlnpqrtsu~}|zyxw{v76543210/.-,+*)('&%$#"!      8@?>=<;:9ABCDEHGFIJKLRQPONMSTUVXWYZ[\]a`_^bmlkjihgfedcnopqrstuvwxyz{|}~Fqpnorstuvwxyzbmlkjihgfedc]a`_^{[\YZUVXWST|}LRQPONMKJI~EHGFCDAB8@?>=<;:976543210/.-,+*)('&%$#"!      u~}|zyxw{vrtspqkomlnXjihgfedb`^]\[ZY_caTWVURSNQPOLMGKJIHDEFv5 None=?@A        77 None247=?@A}E fortran-src A subset of 8 which can only contain values that can be assigned to.I fortran-src=If the expression can be seen as an lvalue, convert it to an E.EHGFIEHGFI None127PXW*U fortran-srcoriginal annotationV fortran-src@unique name for function/variable, after variable renaming phaseW fortran-src8original name for function/variable found in source textX fortran-srcbasic block graphY fortran-src5unique number for each block during dataflow analysis^ fortran-src:Information about potential / actual constant expressions._ fortran-srcinterpreted integer` fortran-srcuninterpreted integera fortran-srcuninterpreted realb fortran-src'binary operation on potential constantsc fortran-src&unary operation on potential constantsu fortran-src+The type of "transformBiM"-family functionsv fortran-src*The type of "transformBi"-family functionsx fortran-srcBasic block graph.z fortran-srcthe underlying graph{ fortran-srcthe entry node(s)| fortran-srcthe exit node(s)} fortran-src Basic block~ fortran-srcEmpty basic block graph fortran-src%Call function on the underlying graph fortran-src1Monadically call function on the underlying graph fortran-src;True iff the expression can be used with varName or srcName fortran-srcBObtain either uniqueName or source name from an ExpValue variable. fortran-src1Obtain the source name from an ExpValue variable. fortran-srcEObtain either uniqueName or source name from an LvSimpleVar variable. fortran-src4Obtain the source name from an LvSimpleVar variable. fortran-srcHGenerate an ExpValue variable with its source name == to its uniqueName. fortran-src?Obtain either ProgramUnit uniqueName or whatever is in the AST. fortran-src?Obtain either ProgramUnit sourceName or whatever is in the AST. fortran-srcNCreate analysis annotations for the program, saving the original annotations. fortran-srcRRemove analysis annotations from the program, restoring the original annotations. fortran-srcReturn list of expressions used as the left-hand-side of assignment statements (including for-loops and function-calls by reference). fortran-srcSReturn list of expressions that are not "left-hand-side" of assignment statements. fortran-src,Is this an expression capable of assignment? fortran-src"Set of names found in an AST node. fortran-srclInitiate (lazy) computation of all LHS variables for each node of the AST so that it may be accessed later. fortran-srcSet of names found in the parts of an AST that are the target of an assignment statement. allLhsVars :: (Annotated b, Data a, Data (b (Analysis a))) => b (Analysis a) -> [Name] fortran-srcZSet of names found in the parts of an AST that are the target of an assignment statement. fortran-src:Set of expressions used -- not defined -- by an AST-block. fortran-src7Set of expression used -- not defined -- by a statement fortran-src4Set of names used -- not defined -- by an AST-block. fortran-src%Set of names defined by an AST-block.NbcdefghijklmSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~NSTUVWXYZ[\]^_`abcpqrstdefghijklmnobcdefghijklm}wxyz{|~vu NoneXG fortran-src(Information about a detected type error. fortran-src%Mapping of names to type information. fortran-srcoAnnotate AST nodes with type information and also return a type environment mapping names to type information. fortran-srcAnnotate AST nodes with type information and also return a type environment mapping names to type information; provided with a starting type environment. fortran-srcAnnotate AST nodes with type information, return a type environment mapping names to type information and return any type errors found; provided with a starting type environment.NonePX  fortran-srcFAnnotate unique names for variable and function declarations and uses. fortran-src`Annotate unique names for variable and function declarations and uses. With external module map. fortran-srcITake the unique name annotations and substitute them into the actual AST. fortran-src,Take a renamed program and undo the renames.NonegNoneNoneX3NoneXNone>PXN  fortran-src1A mapping of program unit names to bblock graphs. fortran-src;Insert basic block graphs into each program unit's analysis fortran-srcVCreate a mapping of (non-module) program unit names to their associated bblock graph. fortran-src2Show a basic block graph in a somewhat decent way. fortran-src,Show a basic block graph without the clutter fortran-srcShow a basic block supergraph fortran-srcFPick out and show the basic block graphs in the program file analysis. fortran-src)Output a graph in the GraphViz DOT format fortran-src.Output a supergraph in the GraphViz DOT format fortran-srcASome helper functions to output some pseudo-code for readability. fortran-src,Fold a function over the graph. Monadically. fortran-src+Map a function over the graph. Monadically. fortran-srcMap a function over the  labels in a graph. Monadically.None27>PXc 9 fortran-srcACallMap : program unit name -> { name of function or subroutine } fortran-src7InductionVarMapByASTBlock : AST-block label -> { name } fortran-srcEMap of loop header nodes to the induction variables within that loop. fortran-src,LoopNodeMap : bblock node -> { bblock node } fortran-src(BackEdgeMap : bblock node -> bblock node fortran-srcThe map of all expressions and whether they are undecided (not present in map), a constant value (Just Constant), or probably not constant (Nothing). fortran-srcAThe map of all parameter variables and their corresponding values fortran-src#Represent "flows" between variables fortran-srcoFlowsGraph : nodes as AST-block (numbered by label), edges showing which definitions contribute to which uses. fortran-srcUDMap : use -> { definition } fortran-srcDUMap : definition -> { use } fortran-src-DefMap : variable name -> { AST-block label } fortran-srcBlockMap : AST-block label -> AST-block Each AST-block has been given a unique number label during analysis of basic blocks. The purpose of this map is to provide the ability to lookup AST-blocks by label. fortran-src?OutF, a function that returns the out-dataflow for a given node fortran-src=InF, a function that returns the in-dataflow for a given node fortran-src=InOutMap : node -> (dataflow into node, dataflow out of node) fortran-src>InOut : (dataflow into the bblock, dataflow out of the bblock) fortran-srcCAn OrderF is a function from graph to a specific ordering of nodes. fortran-src-IDomMap : node -> immediate dominator of node fortran-src#DomMap : node -> dominators of node  fortran-srcCompute dominators of each bblock in the graph. Node A dominates node B when all paths from the start node of that program unit must pass through node A in order to reach node B. That will be represented as the relation (B, [A, ...]) in the DomMap.  fortran-srcjCompute the immediate dominator of each bblock in the graph. The immediate dominator is, in a sense, the closest dominator of a node. Given nodes A and B, you can say that node A is immediately dominated by node B if there does not exist any node C such that: node A dominates node C and node C dominates node B.  fortran-srcJThe postordering of a graph outputs the label after traversal of children.  fortran-srcReversed postordering. fortran-srcJThe preordering of a graph outputs the label before traversal of children. fortran-srcReversed preordering. fortran-src-Apply the iterative dataflow analysis method. fortran-srcBuild a BlockMap from the AST. This can only be performed after analyseBasicBlocks has operated, created basic blocks, and labeled all of the AST-blocks with unique numbers. fortran-src}Build a DefMap from the BlockMap. This allows us to quickly look up the AST-block labels that wrote into the given variable. fortran-srcDataflow analysis for live variables given basic block graph. Muchnick, p. 445: A variable is "live" at a particular program point if there is a path to the exit along which its value may be used before it is redefined. It is "dead" if there is no such path. fortran-srcIterate KILL" set through a single basic block. fortran-srcIterate GEN" set through a single basic block. fortran-srcKILL set for a single AST-block. fortran-srcGEN set for a single AST-block. fortran-srcaReaching definitions dataflow analysis. Reaching definitions are the set of variable-defining AST-block labels that may reach a program point. Suppose AST-block with label A defines a variable named v. Label A may reach another program point labeled P if there is at least one program path from label A to label P that does not redefine variable v. fortran-srchdef-use map: map AST-block labels of defining AST-blocks to the AST-blocks that may use the definition. fortran-srcInvert the DUMap into a UDMap fortran-srcnuse-def map: map AST-block labels of variable-using AST-blocks to the AST-blocks that define those variables. fortran-src$Convert a UD or DU Map into a graph. fortran-src6"Flows-To" analysis. Represent def-use map as a graph. fortran-srcOCreate a map (A -> Bs) where A "flows" or contributes towards the variables Bs. fortran-src3Evaluate possible constant expressions within tree. fortran-srcGenerate a constant-expression map with information about the expressions (identified by insLabel numbering) in the ProgramFile pf (must have analysis initiated & basic blocks generated) . fortran-srcrGet constant-expression information and put it into the AST analysis annotation. Must occur after analyseBBlocks. fortran-srcRAnnotate AST with constant-expression information based on given ParameterVarMap. fortran-srcFind the edges that 'loop back' in the graph; ones where the target node dominates the source node. If the backedges are viewed as (m -> n) then n is considered the  'loop-header' fortran-srcFor each loop in the program, find out which bblock nodes are part of the loop by looking through the backedges (m, n) where n is considered the  'loop-header', delete n from the map, and then do a reverse-depth-first traversal starting from m to find all the nodes of interest. Intersect this with the strongly-connected component containing m, in case of improper& graphs with weird control transfers. fortran-srcnSimilar to loopNodes except it creates a map from loop-header to the set of loop nodes, for each loop-header.  fortran-src9The strongly connected component containing a given node. fortran-srcBasic induction variables are induction variables that are the most easily derived from the syntactic structure of the program: for example, directly appearing in a Do-statement.! fortran-srcFor each loop in the program, figure out the names of the induction variables: the variables that are used to represent the current iteration of the loop." fortran-srccGenerate an induction variable map that is indexed by the labels on AST-blocks within those loops.# fortran-src^For every expression in a loop, try to derive its relationship to a basic induction variable.$ fortran-src.Show some information about dataflow analyses.% fortran-srcxOutputs a DOT-formatted graph showing flow-to data starting at the given AST-Block node in the given Basic Block graph.& fortran-src7Create a call map showing the structure of the program. fortran-srcFinds the transitive closure of a directed graph. Given a graph G=(V,E), its transitive closure is the graph: G* = (V,E*) where E*={(i,j): i,j in V and there is a path from i to j in G} tc :: (DynGraph gr) => gr a b -> gr a () tc g = newEdges  insNodes ln empty where ln = labNodes g newEdges = [ toLEdge (u, v) () | (u, _) <- ln, (_, v) <- bfen (outU g u) g ] outU gr = map toEdge . out gr fortran-srcbasic block graph fortran-src'initialisation for in and out dataflows fortran-srcordering function fortran-src.compute the in-flow given an out-flow function fortran-src.compute the out-flow given an in-flow function fortran-srcfinal dataflow for each node fortran-srcresult of reaching definitionsB^_`abc      !"#$%&B    ^_`abc& !"#$% None27PXs1 fortran-srcA set of decoded mod files.2 fortran-src"The data stored in the "mod files"3 fortran-src8A map of variables => their constant expression if known4 fortran-src^A map of aliases => strings, in order to save space and share structure for repeated strings.5 fortran-srcxMap of unique variable name to the unique name of the program unit where it was defined, and the corresponding SrcSpan.6 fortran-src@Context of a declaration: the ProgramUnit where it was declared.: fortran-src(uniqName, srcName); fortran-src(uniqName, srcName)< fortran-src1Standard ending of fortran-src-format "mod files"= fortran-src@Empty set of mod files. (future proof: may not always be a list)> fortran-srcStarting point.? fortran-srcExtracts the module map, declaration map and type analysis from an analysed and renamed ProgramFile, then inserts it into the ModFile.@ fortran-src}Generate a fresh ModFile from the module map, declaration map and type analysis of a given analysed and renamed ProgramFile.A fortran-srclLooks up the raw "other data" that may be stored in a ModFile by applications that make use of fortran-src.B fortran-srcsGet a list of the labels present in the "other data" of a ModFile. More of a meta-programming / debugging feature.C fortran-srcAllows modification insertionmdeletion of "other data" that may be stored in a ModFile by applications that make use of fortran-src. See < for more information about the interface of this function.D fortran-src;Convert ModFile to a strict ByteString for writing to file.E fortran-srcmConvert a strict ByteString to a ModFile, if possible. Revert the String aliases according to the StringMap.F fortran-srcExtract the combined module map from a set of ModFiles. Useful for parsing a Fortran file in a large context of other modules.G fortran-srcExtract the combined module map from a set of ModFiles. Useful for parsing a Fortran file in a large context of other modules.H fortran-srcExtract the combined declaration map from a set of ModFiles. Useful for parsing a Fortran file in a large context of other modules.I fortran-srcAExtract the combined string map of ModFiles. Mainly internal use.J fortran-srcAExtract the combined string map of ModFiles. Mainly internal use.K fortran-srcJGet the associated Fortran filename that was used to compile the ModFile.L fortran-srclCreate a map that links all unique variable/function names in the ModFiles to their corresponding filename.M fortran-srczExtract all module maps (name -> environment) by collecting all of the stored module maps within the PUModule annotation.N fortran-srcVExtract map of declared variables with their associated program unit and source span. fortran-srcuExtract a string map from the given data, leaving behind aliased values in place of strings in the returned version. fortran-srckRewrite the data with the string map aliases replaced by the actual values (implicitly sharing structure). fortran-src7Extract a map of variables assigned to constant values.123456789:;<=>?@ABCDEFGHIJKLMN<21>=ABC@?DE4536789:;MNKIHFGJLNone [\]^_`abcd dc[\]^_`abNone=?FhOfghigfhi9 9 None=?Fhjklmkjlm9 9 None=?Fh nopqrstuvw onprtwqsuv9 9 None=?Fhxyz{yxz{9 9 None=?Fh/|}~}|~9 9 None fortran-srcPDeduce the type of parser from the filename and parse the contents of the file. fortran-srcyDeduce the type of parser from the filename and parse the contents of the file, within the context of given "mod files". fortran-src7Given a FortranVersion, parse the contents of the file. fortran-srcaGiven a FortranVersion, parse the contents of the file, within the context of given "mod files".   !"#$%&'()*+,-./0123456789:;<==>>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^^_`abbcdefghiijklmnnopqrstuvwxyzz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~   tDECLMNO.FGUVQRSHIKJmnqpsrklo#98*$&\7B)5:;uv                                                         ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 5 6 7 8 9 : ; < = > ? @ A B C C D E F G H H I I J J K L M N N O P Q R S S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j j k l m n o p q r s t t u v w x x y z { | } ~                                                                                                                                                                         ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                   ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                      ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S TUVWXYZ[\]^_`abcdefghijjklmnopqrstuvwxyz{|}~W        !"#$%&'(((((((((()(fortran-src-0.3.0-HYtHVMLWYXtCtJd9jdxIfbLanguage.Fortran.Parser.Utils$Language.Fortran.Util.FirstParameter%Language.Fortran.Util.SecondParameterLanguage.Fortran.Util.PositionLanguage.Fortran.ParserMonadLanguage.Fortran.IntrinsicsLanguage.Fortran.Lexer.FreeForm Language.Fortran.Lexer.FixedFormLanguage.Fortran.ASTLanguage.Fortran.PrettyPrintLanguage.Fortran.LValueLanguage.Fortran.AnalysisLanguage.Fortran.Analysis.Types"Language.Fortran.Analysis.Renaming.Language.Fortran.Transformation.TransformMonad(Language.Fortran.Transformation.Grouping8Language.Fortran.Transformation.Disambiguation.Intrinsic7Language.Fortran.Transformation.Disambiguation.Function!Language.Fortran.Analysis.BBlocks"Language.Fortran.Analysis.DataFlowLanguage.Fortran.Util.ModFileLanguage.Fortran.Transformer!Language.Fortran.Parser.Fortran95!Language.Fortran.Parser.Fortran90!Language.Fortran.Parser.Fortran77!Language.Fortran.Parser.Fortran66#Language.Fortran.Parser.Fortran2003Language.Fortran.Parser.AnyData.Map.StrictalterreadReal readIntegerGFirstParametergetFirstParameter'setFirstParameter'FirstParametergetFirstParametersetFirstParameter$fGFirstParameterU1[]$fGFirstParameter:*:e$fGFirstParameter:+:e$fGFirstParameterM1e$fGFirstParameterK1e$fGFirstParameterK1e0SecondParametergetSecondParametersetSecondParameter$fGSecondParameter:+:e$fGSecondParameterM1e$fGSecondParameterK1e$fGSecondParameter'K1e$fGSecondParameter'K1e0$fGSecondParameter':*:e$fGSecondParameter'M1e$fParameterLeaf:*:$fParameterLeafM1$fGSecondParameter:*:eSpannedgetSpansetSpanSrcSpanPositionposAbsoluteOffset posColumnposLinefilePathposPragmaOffsetLocgetPos initPositionlineColapparentLineColapparentFilePathcolumnDistance lineDistance spannedLines initSrcSpan$fShowPosition$fBinaryPosition $fOutSrcSpan $fShowSrcSpan$fBinarySrcSpan$fSpannedSrcSpan $fEqPosition $fOrdPosition$fDataPosition$fGenericPosition $fEqSrcSpan $fOrdSrcSpan $fDataSrcSpan$fGenericSrcSpanTokeofTokenParseunParse LastToken getLastTokenParseErrorSimpleerrorPos errorFilenameerrorMsg ParseResultParseOk ParseFailed ParseErrorerrPos errLastToken errFilenameerrMsg ParseState psAlexInputpsParanthesesCount psVersion psFilename psContextContextConStartConData ConImplicit ConNamelist ConCommonParanthesesCountpcActual pcHasReached0FortranVersion Fortran66 Fortran77Fortran77ExtendedFortran77Legacy Fortran90 Fortran95 Fortran2003 Fortran2008fortranVersionAliasesselectFortranVersiontokenMsgfromParseResultUnsafe fromRightfromParseResult getVersionputAlexgetAlex topContext popContext pushContext getPosition getSrcSpangetParanthesesCountresetParincPardecPar throwIOerrorrunParserunParseUnsafe evalParse execParse collectTokenscollectTokensSafe$fShowFortranVersion$fExceptionParseError$fShowParseError$fFunctorParseResult$fShowParseErrorSimple$fMonadErrorParseErrorParse$fMonadStateParseStateParse$fApplicativeParse$fFunctorParse $fMonadParse$fOrdFortranVersion$fEqFortranVersion$fDataFortranVersion$fGenericFortranVersion$fShowParanthesesCount$fEqParanthesesCount $fShowContext $fEqContext$fShowParseStateIntrinsicsTable IntrinsicTypeITReal ITInteger ITComplexITDouble ITLogical ITCharacterITParamgetVersionIntrinsicsgetIntrinsicReturnTypegetIntrinsicDefsUsesgetIntrinsicNames isIntrinsic allIntrinsics$fShowIntrinsicType$fEqIntrinsicType$fOrdIntrinsicType$fGenericIntrinsicType$fShowIntrinsicsEntry$fEqIntrinsicsEntry$fOrdIntrinsicsEntry$fGenericIntrinsicsEntry AlexAccPredAlexAcc AlexAccNone AlexAccSkipAlexAccSkipPred AlexLastAccAlexNone AlexLastSkip AlexReturnAlexEOF AlexErrorAlexSkip AlexTokenAlexAddrAlexA# SpecifiesType isTypeSpecTokenTIdTCommentTStringTIntegerLiteral TRealLiteral TBozLiteralTCommaTComma2 TSemiColonTColon TDoubleColon TOpAssignTArrowTPercentTLeftPar TLeftPar2 TRightPar TLeftInitPar TRightInitPar TOpCustomTOpExpTOpPlusTOpMinusTStar TOpDivisionTSlashTOpOrTOpAndTOpNot TOpEquivalentTOpNotEquivalentTOpLTTOpLETOpEQTOpNETOpGTTOpGETLogicalLiteralTProgram TEndProgram TFunction TEndFunctionTResultTPure TElemental TRecursive TSubroutineTEndSubroutine TBlockData TEndBlockDataTModule TEndModule TContainsTUseTOnlyTImport TAbstract TInterface TEndInterface TProcedureTModuleProcedure TAssignment TOperatorTCallTReturnTEntryTIncludeTBindTCTName TAllocatable TAsynchronous TDimension TExternalTIntent TIntrinsic TNonIntrinsic TOptional TParameterTPointerTPrivateTPublic TProtectedTSaveTTargetTValue TVolatileTInTOutTInOutTData TNamelist TImplicit TEquivalenceTCommonTFormatTBlob TAllocateTStatTErrMsgTSource TDeallocateTNullifyTNoneTGotoTAssignTTo TContinueTStopTPauseTDoTEndDoTWhileTIfTThenTElseTElsifTEndIfTCase TSelectCase TEndSelectTDefaultTCycleTExitTForall TEndForallTWhere TElsewhere TEndWhereTTypeTEndType TSequenceTClassTEnum TEnumeratorTEndEnumTKindTLenTIntegerTRealTDoublePrecisionTLogical TCharacterTComplexTOpenTCloseTReadTWriteTPrint TBackspaceTRewindTInquireTEndfileTEndTNewlineTEOFTFlushTUnitTIOStatTIOMsgTErrMove ContinuationCharNewlineUser LexAction AlexInput aiSourceBytes aiPosition aiEndOffsetaiPreviousCharaiLexeme aiStartCodeaiPreviousTokenaiPreviousTokensInLine StartCodescActualscStatusStartCodeStatusReturnStableLexeme lexemeMatch lexemeStart lexemeEnd lexemeIsCmt alex_tab_size alex_base alex_table alex_check alex_deflt alex_accept alex_actionsformatP followsDoP followsColonPlabelledWhereP selectorPifConditionEndPopPpartOfExpOrPointerAssignmentPprecedesDoubleColon parenLevel allocateP attributePbindPconstructNameP genericSpecPnotDefinedOperP typeSpecPresultPnotPrecedingDotPfollowsIntentPfollowsProcedureP followsBindP followsCP followsFlushPuseStPcaseStP assignStPprevTokenConstrnextTokenConstr seenConstr fillConstr adjustCommentleftParcommaslashOrDivisionaddSpanaddSpanAndMatch getLexeme putLexeme resetLexemegetMatchputMatchupdatePreviousTokenaddToPreviousTokensInLinecheckPreviousTokensInLine getLexemeSpan lexCharactertoSCstabiliseStartCodenormaliseStartCodeinvalidPositionisValidPosition initLexemevanillaAlexInput updateLexeme alexGetBytealexInputPrevChar currentCharadvanceWithoutContinuationisContinuationskipContinuation skipCCommentadvancelexHashlexerlexer'initParseStatecollectFreeTokensscCscIscNscT alex_action_0 alex_action_1 alex_action_2 alex_action_3 alex_action_5 alex_action_6 alex_action_7 alex_action_8 alex_action_9alex_action_10alex_action_11alex_action_12alex_action_13alex_action_14alex_action_15alex_action_16alex_action_17alex_action_18alex_action_19alex_action_20alex_action_21alex_action_22alex_action_23alex_action_24alex_action_25alex_action_26alex_action_27alex_action_28alex_action_29alex_action_30alex_action_31alex_action_32alex_action_33alex_action_34alex_action_35alex_action_36alex_action_37alex_action_38alex_action_39alex_action_40alex_action_41alex_action_42alex_action_43alex_action_44alex_action_45alex_action_46alex_action_47alex_action_48alex_action_49alex_action_50alex_action_51alex_action_52alex_action_53alex_action_54alex_action_55alex_action_56alex_action_57alex_action_58alex_action_59alex_action_60alex_action_61alex_action_62alex_action_63alex_action_64alex_action_65alex_action_66alex_action_67alex_action_68alex_action_69alex_action_70alex_action_71alex_action_72alex_action_73alex_action_74alex_action_75alex_action_76alex_action_77alex_action_78alex_action_79alex_action_80alex_action_81alex_action_82alex_action_83alex_action_84alex_action_85alex_action_86alex_action_87alex_action_88alex_action_89alex_action_90alex_action_91alex_action_92alex_action_93alex_action_94alex_action_95alex_action_96alex_action_97alex_action_98alex_action_99alex_action_100alex_action_101alex_action_102alex_action_103alex_action_104alex_action_105alex_action_106alex_action_107alex_action_108alex_action_109alex_action_110alex_action_111alex_action_112alex_action_113alex_action_114alex_action_115alex_action_116alex_action_117alex_action_118alex_action_119alex_action_120alex_action_121alex_action_122alex_action_123alex_action_124alex_action_125alex_action_126alex_action_127alex_action_128alex_action_129alex_action_130alex_action_131alex_action_132alex_action_133alex_action_134alex_action_135alex_action_136alex_action_137alex_action_138alex_action_139alex_action_140alex_action_141alex_action_142alex_action_143alex_action_144alex_action_145alex_action_146alex_action_147alex_action_148alex_action_149alex_action_150alex_action_151alex_action_152alex_action_153alex_action_154alex_action_155alex_action_156alex_action_157alex_action_158alex_action_159alex_action_160alex_action_161alex_action_162alex_action_163alex_action_164alex_action_165alex_action_166alex_action_167alex_action_168alex_action_169alex_action_170alex_action_171alex_action_172alex_action_173alex_action_174alex_action_175alex_action_176alex_action_177alex_action_178alex_action_179alex_action_180alex_action_181alex_action_182alex_action_183alex_action_184alex_action_185alex_action_186alex_action_187alex_action_188alex_action_189alex_action_190alex_action_191alex_action_192alex_action_193alex_action_194alex_action_195alex_action_196alex_action_197alex_action_198alex_action_199alex_action_200alex_action_201alex_action_202alex_action_203alexIndexInt16OffAddralexIndexInt32OffAddr quickIndexalexScan alexScanUser alex_scan_tkn alexAndPredalexPrevCharIsalexPrevCharMatchesalexPrevCharIsOneOfalexRightContext$fSpannedLexeme $fTokToken$fSpannedToken$fFirstParameterTokenSrcSpan$fLastTokenAlexInputToken$fLocAlexInput$fSpecifiesType[]$fSpecifiesTypeToken $fShowLexeme$fShowStartCodeStatus$fShowStartCode $fEqToken $fShowToken $fDataToken$fGenericToken$fShowAlexInputaiBytesaiWhiteSensitiveCharCountaiCaseSensitive aiInFormataiFortranVersion TLeftArrayParTRightArrayParTDot TStructureTRecordTUnionTMap TEndStructure TEndUnionTEndMapTEndif TCaseDefaultTDoWhile TTypePrint TAutomaticTIntTBozInt TExponentTBool TAmpersandTOpXOr THollerithTLabellexNcollectFixedTokenscollectFixedTokensSafe $fOrdTokenNamedgetNamesetNameProgramUnitNameNamelessBlockDataNamelessComment NamelessMain Conditioned getConditionLabeledgetLabel getLastLabelsetLabel SpannedPair getTransSpan Annotated getAnnotation setAnnotationmodifyAnnotationBinaryOpAddition SubtractionMultiplicationDivisionExponentiation ConcatenationGTGTELTLTEEQNEOrXOrAnd Equivalent NotEquivalent BinCustomUnaryOpPlusMinusNotUnCustomDimensionDeclarator Declarator DeclVariable DeclArrayValue ValIntegerValReal ValComplex ValString ValHollerith ValVariable ValIntrinsic ValLogical ValOperator ValAssignmentValTypeValStarValColonIndexIxSingleIxRange ExpressionExpValue ExpBinaryExpUnary ExpSubscript ExpDataRefExpFunctionCall ExpImpliedDoExpInitialisation ExpReturnSpecDoSpecification FlushSpecFSUnitFSIOStatFSIOMsgFSErr FormatItem FIFormatList FIHollerith FIDelimiterFIFieldDescriptorDEFGFIFieldDescriptorAILFIBlankDescriptor FIScaleFactorUnionMap StructureItem StructFields StructUnionStructStructure DataGroupNamelist CommonGroup ImpElement ImpCharacterImpRangeImpListAllocOptAOStatAOErrMsgAOSource ControlPairIntentInOutInOut AttributeAttrAllocatableAttrAsynchronous AttrDimension AttrExternal AttrIntent AttrIntrinsic AttrOptional AttrParameter AttrPointer AttrPrivate AttrProtected AttrPublicAttrSave AttrSuffix AttrTarget AttrValue AttrVolatileArgumentUse UseRenameUseID ModuleNature ModIntrinsicModNonIntrinsicOnly Exclusive Permissive ForallHeader ProcInterfaceProcInterfaceNameProcInterfaceTypeProcDecl Statement StDeclaration StStructureStIntent StOptionalStPublic StPrivate StProtectedStSave StDimension StAllocatableStAsynchronous StPointerStTargetStValue StVolatileStData StAutomatic StNamelist StParameter StExternal StIntrinsicStCommon StEquivalenceStFormat StImplicitStEntry StIncludeStDo StDoWhileStEnddoStCycleStExit StIfLogicalStIfArithmeticStIfThenStElseStElsifStEndif StSelectCaseStCase StEndcase StFunctionStExpressionAssignStPointerAssign StLabelAssignStGotoUnconditionalStGotoAssignedStGotoComputedStCallStReturn StContinueStStopStPauseStReadStRead2StWriteStPrint StTypePrintStOpenStCloseStFlush StInquireStRewind StRewind2 StBackspace StBackspace2 StEndfile StEndfile2 StAllocate StNullify StDeallocateStWhereStWhereConstruct StElsewhere StEndWhereStUseStModuleProcedure StProcedureStType StEndType StSequenceStForallStForallStatement StEndForallStImportStEnum StEnumerator StEndEnum StFormatBogusBlock BlStatementBlForallBlIfBlCaseBlDo BlDoWhile BlInterface BlCommentCommentSuffixSfxBindPrefix PfxRecursive PfxElementalPfxPure PrefixSuffixSuffixesPrefixes ProgramUnitPUMainPUModule PUSubroutine PUFunction PUBlockData PUComment ProgramFileMetaInfo miVersion miFilenameSelectorTypeSpec CharacterLen CharLenStar CharLenColon CharLenExp CharLenIntBaseType TypeIntegerTypeRealTypeDoublePrecision TypeComplexTypeDoubleComplex TypeLogical TypeCharacter TypeCustom ClassStar ClassCustomTypeByteAListNameA0fromList fromList'fromReverseListfromReverseList'aConsaReverseaStripaStrip'aMapcharLenSelector pfSetFilename pfGetFilename emptyPrefixes emptySuffixesemptyPrefixSuffixvalidPrefixSuffixprogramUnitBodyupdateProgramUnitBodyprogramUnitSubprogramssetInitialisationnonExecutableStatementexecutableStatementexecutableStatementBlocknonExecutableStatementBlock$fOutFortranVersion$fSpannedEither $fOutAList$fSpannedAList$fSecondParameterAListSrcSpan$fFirstParameterALista$fFunctorAList$fOutCharacterLen$fBinaryCharacterLen $fOutBaseType$fBinaryBaseType $fOutMetaInfo $fOutPrefix$fSpannedPrefix$fSecondParameterPrefixSrcSpan$fFirstParameterPrefixa $fOutComment $fOutOnly$fOutModuleNature $fOutIntent$fOutImpElement$fSpannedImpElement"$fSecondParameterImpElementSrcSpan$fFirstParameterImpElementa $fOutUnaryOp$fBinaryUnaryOp $fOutBinaryOp$fBinaryBinaryOp$fOutForallHeader $fOutAllocOpt$fOutControlPair$fOutDimensionDeclarator$fOutDeclarator $fOutSelector $fOutTypeSpec $fOutValue$fOutFlushSpec$fOutDoSpecification $fOutIndex$fOutExpression$fOutFormatItem $fOutNamelist $fOutUnionMap$fOutStructureItem$fOutDataGroup$fOutCommonGroup $fOutBlock $fOutImpList$fOutAttribute$fOutUse $fOutArgument$fOutProcInterface $fOutProcDecl$fOutStatement $fOutSuffix$fOutProgramUnit$fSpannedAllocOpt$fSpannedControlPair$fSpannedDimensionDeclarator$fSpannedDeclarator$fSpannedFlushSpec$fSpannedDoSpecification$fSpannedIndex$fSpannedExpression$fSpannedFormatItem$fSpannedNamelist$fSpannedUnionMap$fSpannedStructureItem$fSpannedDataGroup$fSpannedCommonGroup$fSpannedBlock$fSpannedImpList$fSpannedSelector$fSpannedProcInterface$fSpannedProcDecl$fSpannedTypeSpec$fSpannedAttribute $fSpannedUse$fSpannedArgument$fSpannedStatement$fSpannedSuffix$fSpannedProgramUnit $fSecondParameterAllocOptSrcSpan#$fSecondParameterControlPairSrcSpan+$fSecondParameterDimensionDeclaratorSrcSpan"$fSecondParameterDeclaratorSrcSpan!$fSecondParameterFlushSpecSrcSpan'$fSecondParameterDoSpecificationSrcSpan$fSecondParameterIndexSrcSpan"$fSecondParameterExpressionSrcSpan"$fSecondParameterFormatItemSrcSpan $fSecondParameterNamelistSrcSpan $fSecondParameterUnionMapSrcSpan%$fSecondParameterStructureItemSrcSpan!$fSecondParameterDataGroupSrcSpan#$fSecondParameterCommonGroupSrcSpan$fSecondParameterImpListSrcSpan!$fSecondParameterAttributeSrcSpan $fSecondParameterSelectorSrcSpan%$fSecondParameterProcInterfaceSrcSpan $fSecondParameterProcDeclSrcSpan $fSecondParameterTypeSpecSrcSpan$fSecondParameterUseSrcSpan $fSecondParameterArgumentSrcSpan!$fSecondParameterStatementSrcSpan$fSecondParameterBlockSrcSpan$fSecondParameterSuffixSrcSpan#$fSecondParameterProgramUnitSrcSpan$fFirstParameterAllocOpta$fFirstParameterControlPaira$$fFirstParameterDimensionDeclaratora$fFirstParameterDeclaratora$fFirstParameterFlushSpeca $fFirstParameterDoSpecificationa$fFirstParameterIndexa$fFirstParameterExpressiona$fFirstParameterFormatItema$fFirstParameterNamelista$fFirstParameterUnionMapa$fFirstParameterStructureItema$fFirstParameterDataGroupa$fFirstParameterCommonGroupa$fFirstParameterImpLista$fFirstParameterAttributea$fFirstParameterSelectora$fFirstParameterProcInterfacea$fFirstParameterProcDecla$fFirstParameterTypeSpeca$fFirstParameterUsea$fFirstParameterArgumenta$fFirstParameterStatementa$fFirstParameterBlocka$fFirstParameterSuffixa$fFirstParameterProgramUnita$fOutProgramFile$fSpannedProgramFile$fAnnotatedAllocOpt$fAnnotatedControlPair$fAnnotatedDimensionDeclarator$fAnnotatedDeclarator$fAnnotatedFlushSpec$fAnnotatedDoSpecification$fAnnotatedIndex$fAnnotatedExpression$fAnnotatedFormatItem$fAnnotatedNamelist$fAnnotatedUnionMap$fAnnotatedStructureItem$fAnnotatedDataGroup$fAnnotatedCommonGroup$fAnnotatedImpElement$fAnnotatedImpList$fAnnotatedAttribute$fAnnotatedSelector$fAnnotatedProcInterface$fAnnotatedProcDecl$fAnnotatedTypeSpec$fAnnotatedUse$fAnnotatedArgument$fAnnotatedStatement$fAnnotatedBlock$fAnnotatedProgramUnit$fAnnotatedAList$fSpannedPaira[]$fSpannedPaira[]0$fSpannedPairab $fSpanned(,,)$fSpanned(,,)0$fSpanned(,,)1$fSpanned(,,)2 $fSpanned(,) $fSpanned(,)0 $fSpanned(,)1 $fSpanned[]$fLabeledBlock$fConditionedStatement$fConditionedBlock$fBinaryProgramUnitName$fNamedProgramUnit $fEqAList $fShowAList $fDataAList$fGenericAList$fOrdCharacterLen$fEqCharacterLen$fShowCharacterLen$fDataCharacterLen$fGenericCharacterLen $fOrdBaseType $fEqBaseType$fShowBaseType$fDataBaseType$fGenericBaseType $fEqMetaInfo$fShowMetaInfo$fDataMetaInfo$fGenericMetaInfo $fEqPrefix $fShowPrefix $fDataPrefix$fGenericPrefix$fFunctorPrefix $fEqComment $fShowComment $fDataComment$fGenericComment$fFunctorComment$fEqOnly $fShowOnly $fDataOnly $fGenericOnly$fEqModuleNature$fShowModuleNature$fDataModuleNature$fGenericModuleNature $fEqIntent $fShowIntent $fDataIntent$fGenericIntent$fEqImpElement$fShowImpElement$fDataImpElement$fGenericImpElement$fFunctorImpElement $fEqUnaryOp $fOrdUnaryOp $fShowUnaryOp $fDataUnaryOp$fGenericUnaryOp $fEqBinaryOp $fOrdBinaryOp$fShowBinaryOp$fDataBinaryOp$fGenericBinaryOp$fEqExpression$fShowExpression$fDataExpression$fGenericExpression$fFunctorExpression $fEqValue $fShowValue $fDataValue$fGenericValue$fFunctorValue $fEqIndex $fShowIndex $fDataIndex$fGenericIndex$fFunctorIndex$fEqDoSpecification$fShowDoSpecification$fDataDoSpecification$fGenericDoSpecification$fFunctorDoSpecification $fEqStatement$fShowStatement$fDataStatement$fGenericStatement$fFunctorStatement$fEqDeclarator$fShowDeclarator$fDataDeclarator$fGenericDeclarator$fFunctorDeclarator$fEqDimensionDeclarator$fShowDimensionDeclarator$fDataDimensionDeclarator$fGenericDimensionDeclarator$fFunctorDimensionDeclarator $fEqFlushSpec$fShowFlushSpec$fDataFlushSpec$fGenericFlushSpec$fFunctorFlushSpec$fEqFormatItem$fShowFormatItem$fDataFormatItem$fGenericFormatItem$fFunctorFormatItem$fEqStructureItem$fShowStructureItem$fDataStructureItem$fGenericStructureItem$fFunctorStructureItem $fEqUnionMap$fShowUnionMap$fDataUnionMap$fGenericUnionMap$fFunctorUnionMap $fEqAttribute$fShowAttribute$fDataAttribute$fGenericAttribute$fFunctorAttribute $fEqSuffix $fShowSuffix $fDataSuffix$fGenericSuffix$fFunctorSuffix $fEqTypeSpec$fShowTypeSpec$fDataTypeSpec$fGenericTypeSpec$fFunctorTypeSpec $fEqSelector$fShowSelector$fDataSelector$fGenericSelector$fFunctorSelector $fEqDataGroup$fShowDataGroup$fDataDataGroup$fGenericDataGroup$fFunctorDataGroup $fEqNamelist$fShowNamelist$fDataNamelist$fGenericNamelist$fFunctorNamelist$fEqCommonGroup$fShowCommonGroup$fDataCommonGroup$fGenericCommonGroup$fFunctorCommonGroup $fEqImpList $fShowImpList $fDataImpList$fGenericImpList$fFunctorImpList $fEqAllocOpt$fShowAllocOpt$fDataAllocOpt$fGenericAllocOpt$fFunctorAllocOpt$fEqControlPair$fShowControlPair$fDataControlPair$fGenericControlPair$fFunctorControlPair $fEqArgument$fShowArgument$fDataArgument$fGenericArgument$fFunctorArgument$fEqUse $fShowUse $fDataUse $fGenericUse $fFunctorUse$fEqForallHeader$fShowForallHeader$fDataForallHeader$fGenericForallHeader$fFunctorForallHeader$fEqProcInterface$fShowProcInterface$fDataProcInterface$fGenericProcInterface$fFunctorProcInterface $fEqProcDecl$fShowProcDecl$fDataProcDecl$fGenericProcDecl$fFunctorProcDecl $fEqBlock $fShowBlock $fDataBlock$fGenericBlock$fFunctorBlock$fEqProgramUnit$fShowProgramUnit$fDataProgramUnit$fGenericProgramUnit$fFunctorProgramUnit$fEqProgramFile$fShowProgramFile$fDataProgramFile$fGenericProgramFile$fFunctorProgramFile$fOrdProgramUnitName$fEqProgramUnitName$fShowProgramUnitName$fDataProgramUnitName$fGenericProgramUnitNamePrettypprint'IndentablePrettypprint IndentationtooOldnewlineincIndentationindentoverlay fixedFormpprintAndRenderendGencommaSep$fFirstParameterValue[]$fIndentablePrettyUnionMap$fIndentablePretty[]$fIndentablePretty[]0$fIndentablePrettyProgramFile$fIndentablePrettyMaybe$fPrettyBinaryOp$fPrettyUnaryOp$fPrettyDimensionDeclarator$fPrettyDeclarator$fIndentablePrettyStructureItem $fPrettyValue $fPrettyIndex$fPrettyExpression$fPrettyImpElement$fPrettyDataGroup$fPrettyNamelist$fPrettyCommonGroup$fPrettyImpList$fPrettyAllocOpt$fPrettyControlPair$fPrettyDoSpecification$fPrettyFlushSpec$fPrettyFormatItem$fPrettyIntent$fPrettySuffix$fPrettyAttribute$fPrettyArgument $fPrettyUse $fPrettyOnly$fPrettyProcDecl$fPrettyProcInterface$fPrettyStatement$fPrettySelector$fPrettyTypeSpec$fPrettyCharacterLen$fPrettyBaseType $fPrettyAList $fPretty[] $fPrettyMaybe$fIndentablePrettyBlock$fIndentablePrettyProgramUnit$fIndentablePrettyaLValue LvSimpleVar LvSubscript LvDataReftoLValue$fSpannedLValue$fAnnotatedLValue$fSecondParameterLValueSrcSpan$fFirstParameterLValuea $fEqLValue $fShowLValue $fDataLValue$fGenericLValue$fFunctorLValueAnalysisprevAnnotation uniqueName sourceNamebBlocksinsLabel moduleEnvidType allLhsVarsAnnconstExpConstantConstIntConstUninterpIntConstUninterpReal ConstBinary ConstUnaryIDTypeidVTypeidCType ConstructType CTFunction CTSubroutine CTExternal CTVariableCTArray CTParameter CTIntrinsicModEnvNameType NTSubprogram NTVariable NTIntrinsic TransFuncM TransFuncBBNodeBBGrbbgrGr bbgrEntries bbgrExitsBB bbgrEmptybbgrMapbbgrMapMisNamedExpressionvarNamesrcName lvVarName lvSrcNamegenVarpuName puSrcName initAnalysis stripAnalysislhsExprsrhsExprsisLExprallVarsanalyseAllLhsVarsanalyseAllLhsVars1 allLhsVars blockRhsExprs blockVarUses blockVarDefs$fDataGr $fOutNameType$fBinaryNameType$fBinaryConstructType$fOutConstructType$fBinaryIDType $fOutIDType$fBinaryConstant $fOutConstant $fOutAnalysis$fFunctorAnalysis $fDataBBGr $fShowBBGr$fEqBBGr $fGenericBBGr$fShowNameType $fEqNameType $fOrdNameType$fDataNameType$fGenericNameType$fOrdConstructType$fEqConstructType$fShowConstructType$fDataConstructType$fGenericConstructType $fOrdIDType $fEqIDType $fShowIDType $fDataIDType$fGenericIDType$fShowConstant $fOrdConstant $fEqConstant$fGenericConstant$fDataConstant$fDataAnalysis$fShowAnalysis $fEqAnalysis$fGenericAnalysis TypeErrorTypeEnv analyseTypesanalyseTypesWithEnvanalyseAndCheckTypesWithEnvextractTypeEnv$fShowInferState ModuleMapanalyseRenamesanalyseRenamesWithModuleMaprenameunrename$fShowRenameState$fEqRenameState Transform runTransformgetProgramFileputProgramFilemodifyProgramFile groupForallgroupIfgroupDogroupLabeledDo groupCasedisambiguateIntrinsicdisambiguateFunction$fIndexedExpression$fIndexedArgument SuperBBGrsuperBBGrGraphsuperBBGrClusterssuperBBGrEntries ASTExprNode ASTBlockNode BBlockMapanalyseBBlocks genBBlockMap genSuperBBGrfindLabeledBBlockshowBBGrshowAnalysedBBGr showSuperBBGr showBBlocks bbgrToDOTsuperBBGrToDOT showBlockCallMapDerivedInductionMap InductionExprIETopIELinearIEBottomInductionVarMapByASTBlockInductionVarMap LoopNodeMap BackEdgeMap ConstExpMapParameterVarMap VarFlowsMap FlowsGraphUDMapDUMapDefMapBlockMapOutFInFInOutMapOrderFIDomMapDomMapASTExprNodeSetASTExprNodeMapASTBlockNodeSetASTBlockNodeMap BBNodeSet BBNodeMap dominators iDominators postOrder revPostOrderpreOrder revPreOrderdataFlowSolver genBlockMap genDefMapliveVariableAnalysisreachingDefinitionsgenDUMap duMapToUdMapgenUDMapgenFlowsToGraphgenVarFlowsToMapgenConstExpMapanalyseConstExpsanalyseParameterVarsgenBackEdgeMap loopNodesgenLoopNodeMapsccWithgenInductionVarMapgenInductionVarMapByASTBlockgenDerivedInductionMap showDataFlow showFlowsDOT genCallMap$fShowInductionExpr$fEqInductionExpr$fOrdInductionExpr$fGenericInductionExpr$fDataInductionExpr $fShowIEFlow $fEqIEFlow $fOrdIEFlow$fGenericIEFlow $fDataIEFlowModFilesModFile ParamVarMap StringMapDeclMap DeclContextDCMain DCBlockDataDCModule DCFunction DCSubroutine modFileSuffix emptyModFiles emptyModFile regenModFile genModFilelookupModFileDatagetLabelsModFileDataalterModFileData encodeModFile decodeModFilecombinedModuleMapcombinedTypeEnvcombinedDeclMapcombinedStringMapcombinedParamVarMapmoduleFilenamegenUniqNameToFilenameMapextractModuleMapextractDeclMap$fBinaryDeclContext$fBinaryModFile$fOrdDeclContext$fEqDeclContext$fShowDeclContext$fDataDeclContext$fGenericDeclContext $fEqModFile $fOrdModFile $fShowModFile $fDataModFile$fGenericModFileTransformation GroupForallGroupIf GroupCaseGroupDoGroupLabeledDoDisambiguateFunctionDisambiguateIntrinsictransformWithModFiles transform$fEqTransformationstatementParserfunctionParserfortran95Parserfortran95ParserWithModFilesfortran90Parserfortran90ParserWithModFilesexpressionParserfortran77Parserfortran77ParserWithModFilesextended77Parserextended77ParserWithModFileslegacy77Parserlegacy77ParserWithModFileslegacy77ParserWithIncludes includeParserfortran66Parserfortran66ParserWithModFilesfortran2003Parserfortran2003ParserWithModFilesParserWithModFilesParser deduceVersionparserVersionsparserWithModFilesVersionsafter fortranParserfortranParserWithModFilesfortranParserWithVersion#fortranParserWithModFilesAndVersionfortran77intrinsicscomputeAllLhsVarsstatementRhsExprsufoldM'gmapM'nmapM'"fgl-5.7.0.1-3NF37S38Tlz5mLo3YDpp8tData.Graph.Inductive.GraphNode bblockKill bblockGen blockKillblockGen mapToGraphconstantFoldingbasicInductionVarsconvergeinsEdgesextractStringMaprevertStringMapextractParamVarMapHappyStk