@harmoniclabs/pebble 0.1.0-dev1 → 0.1.0-dev2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/dist/IR/IRHash.d.ts +0 -8
- package/dist/IR/IRHash.js +0 -78
- package/dist/IR/IRNodeKind.d.ts +0 -17
- package/dist/IR/IRNodeKind.js +0 -19
- package/dist/IR/IRNodes/BaseIRMetadata.d.ts +0 -3
- package/dist/IR/IRNodes/BaseIRMetadata.js +0 -1
- package/dist/IR/IRNodes/IRApp.d.ts +0 -36
- package/dist/IR/IRNodes/IRApp.js +0 -91
- package/dist/IR/IRNodes/IRCase.d.ts +0 -32
- package/dist/IR/IRNodes/IRCase.js +0 -91
- package/dist/IR/IRNodes/IRConst.d.ts +0 -49
- package/dist/IR/IRNodes/IRConst.js +0 -273
- package/dist/IR/IRNodes/IRConstr.d.ts +0 -30
- package/dist/IR/IRNodes/IRConstr.js +0 -87
- package/dist/IR/IRNodes/IRDelayed.d.ts +0 -31
- package/dist/IR/IRNodes/IRDelayed.js +0 -68
- package/dist/IR/IRNodes/IRError.d.ts +0 -32
- package/dist/IR/IRNodes/IRError.js +0 -44
- package/dist/IR/IRNodes/IRForced.d.ts +0 -31
- package/dist/IR/IRNodes/IRForced.js +0 -69
- package/dist/IR/IRNodes/IRFunc.d.ts +0 -33
- package/dist/IR/IRNodes/IRFunc.js +0 -91
- package/dist/IR/IRNodes/IRHoisted.d.ts +0 -55
- package/dist/IR/IRNodes/IRHoisted.js +0 -212
- package/dist/IR/IRNodes/IRLetted.d.ts +0 -108
- package/dist/IR/IRNodes/IRLetted.js +0 -444
- package/dist/IR/IRNodes/IRNative/IRNativeTag.d.ts +0 -138
- package/dist/IR/IRNodes/IRNative/IRNativeTag.js +0 -204
- package/dist/IR/IRNodes/IRNative/index.d.ts +0 -165
- package/dist/IR/IRNodes/IRNative/index.js +0 -240
- package/dist/IR/IRNodes/IRNative/isForcedNative.d.ts +0 -3
- package/dist/IR/IRNodes/IRNative/isForcedNative.js +0 -18
- package/dist/IR/IRNodes/IRRecursive.d.ts +0 -29
- package/dist/IR/IRNodes/IRRecursive.js +0 -90
- package/dist/IR/IRNodes/IRSelfCall.d.ts +0 -46
- package/dist/IR/IRNodes/IRSelfCall.js +0 -127
- package/dist/IR/IRNodes/IRVar.d.ts +0 -41
- package/dist/IR/IRNodes/IRVar.js +0 -93
- package/dist/IR/IRNodes/index.d.ts +0 -12
- package/dist/IR/IRNodes/index.js +0 -12
- package/dist/IR/IRNodes/utils/dependsByDbns.d.ts +0 -5
- package/dist/IR/IRNodes/utils/dependsByDbns.js +0 -29
- package/dist/IR/IRNodes/utils/isClosedAtDbn.d.ts +0 -2
- package/dist/IR/IRNodes/utils/isClosedAtDbn.js +0 -22
- package/dist/IR/IRNodes/utils/makeArrayLikeProxy.d.ts +0 -1
- package/dist/IR/IRNodes/utils/makeArrayLikeProxy.js +0 -34
- package/dist/IR/IRNodes/utils/mapArrayLike.d.ts +0 -1
- package/dist/IR/IRNodes/utils/mapArrayLike.js +0 -8
- package/dist/IR/IRTerm.d.ts +0 -15
- package/dist/IR/IRTerm.js +0 -1
- package/dist/IR/index.d.ts +0 -5
- package/dist/IR/index.js +0 -5
- package/dist/IR/interfaces/IHash.d.ts +0 -6
- package/dist/IR/interfaces/IHash.js +0 -1
- package/dist/IR/interfaces/IIRParent.d.ts +0 -4
- package/dist/IR/interfaces/IIRParent.js +0 -1
- package/dist/IR/interfaces/IRMetadata.d.ts +0 -3
- package/dist/IR/interfaces/IRMetadata.js +0 -2
- package/dist/IR/interfaces/ToIR.d.ts +0 -5
- package/dist/IR/interfaces/ToIR.js +0 -1
- package/dist/IR/interfaces/index.d.ts +0 -4
- package/dist/IR/interfaces/index.js +0 -4
- package/dist/IR/toUPLC/CompilerOptions.d.ts +0 -80
- package/dist/IR/toUPLC/CompilerOptions.js +0 -98
- package/dist/IR/toUPLC/_internal/_addDepth.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/_addDepth.js +0 -58
- package/dist/IR/toUPLC/_internal/_irToUplc.d.ts +0 -9
- package/dist/IR/toUPLC/_internal/_irToUplc.js +0 -156
- package/dist/IR/toUPLC/_internal/_makeAllNegativeNativesHoisted.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/_makeAllNegativeNativesHoisted.js +0 -12
- package/dist/IR/toUPLC/_internal/_modifyChildFromTo.d.ts +0 -10
- package/dist/IR/toUPLC/_internal/_modifyChildFromTo.js +0 -141
- package/dist/IR/toUPLC/_internal/depth.d.ts +0 -5
- package/dist/IR/toUPLC/_internal/depth.js +0 -8
- package/dist/IR/toUPLC/_internal/findAll.d.ts +0 -3
- package/dist/IR/toUPLC/_internal/findAll.js +0 -99
- package/dist/IR/toUPLC/_internal/getDebruijnInTerm.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/getDebruijnInTerm.js +0 -51
- package/dist/IR/toUPLC/_internal/getDiffDbn.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/getDiffDbn.js +0 -55
- package/dist/IR/toUPLC/_internal/includesLettedTerms.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/includesLettedTerms.js +0 -50
- package/dist/IR/toUPLC/_internal/includesNode.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/includesNode.js +0 -54
- package/dist/IR/toUPLC/_internal/iterTree.d.ts +0 -2
- package/dist/IR/toUPLC/_internal/iterTree.js +0 -93
- package/dist/IR/toUPLC/_internal/lowestCommonAncestor.d.ts +0 -3
- package/dist/IR/toUPLC/_internal/lowestCommonAncestor.js +0 -41
- package/dist/IR/toUPLC/compileIRToUPLC.d.ts +0 -4
- package/dist/IR/toUPLC/compileIRToUPLC.js +0 -118
- package/dist/IR/toUPLC/index.d.ts +0 -2
- package/dist/IR/toUPLC/index.js +0 -2
- package/dist/IR/toUPLC/subRoutines/handleHoistedAndReturnRoot/index.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/handleHoistedAndReturnRoot/index.js +0 -161
- package/dist/IR/toUPLC/subRoutines/handleLetted/findHighestRecursiveParent.d.ts +0 -5
- package/dist/IR/toUPLC/subRoutines/handleLetted/findHighestRecursiveParent.js +0 -14
- package/dist/IR/toUPLC/subRoutines/handleLetted/groupByScope.d.ts +0 -20
- package/dist/IR/toUPLC/subRoutines/handleLetted/groupByScope.js +0 -107
- package/dist/IR/toUPLC/subRoutines/handleLetted/incrementUnboundDbns.d.ts +0 -9
- package/dist/IR/toUPLC/subRoutines/handleLetted/incrementUnboundDbns.js +0 -73
- package/dist/IR/toUPLC/subRoutines/handleLetted/index.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/handleLetted/index.js +0 -304
- package/dist/IR/toUPLC/subRoutines/handleRecursiveTerms.d.ts +0 -3
- package/dist/IR/toUPLC/subRoutines/handleRecursiveTerms.js +0 -32
- package/dist/IR/toUPLC/subRoutines/hoistForcedNatives.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/hoistForcedNatives.js +0 -58
- package/dist/IR/toUPLC/subRoutines/inlineSingleUseApplications.d.ts +0 -1
- package/dist/IR/toUPLC/subRoutines/inlineSingleUseApplications.js +0 -12
- package/dist/IR/toUPLC/subRoutines/markRecursiveHoistsAsForced.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/markRecursiveHoistsAsForced.js +0 -82
- package/dist/IR/toUPLC/subRoutines/performUplcOptimizationsAndReturnRoot/expandFuncsAndReturnRoot.d.ts +0 -4
- package/dist/IR/toUPLC/subRoutines/performUplcOptimizationsAndReturnRoot/expandFuncsAndReturnRoot.js +0 -68
- package/dist/IR/toUPLC/subRoutines/performUplcOptimizationsAndReturnRoot/index.d.ts +0 -5
- package/dist/IR/toUPLC/subRoutines/performUplcOptimizationsAndReturnRoot/index.js +0 -227
- package/dist/IR/toUPLC/subRoutines/replaceClosedLettedWithHoisted.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/replaceClosedLettedWithHoisted.js +0 -13
- package/dist/IR/toUPLC/subRoutines/replaceForcedNativesWithHoisted.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/replaceForcedNativesWithHoisted.js +0 -11
- package/dist/IR/toUPLC/subRoutines/replaceHoistedWithLetted.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/replaceHoistedWithLetted.js +0 -16
- package/dist/IR/toUPLC/subRoutines/replaceNatives/index.d.ts +0 -2
- package/dist/IR/toUPLC/subRoutines/replaceNatives/index.js +0 -16
- package/dist/IR/toUPLC/subRoutines/replaceNatives/nativeToIR.d.ts +0 -3
- package/dist/IR/toUPLC/subRoutines/replaceNatives/nativeToIR.js +0 -520
- package/dist/IR/toUPLC/subRoutines/sanifyTree.d.ts +0 -5
- package/dist/IR/toUPLC/subRoutines/sanifyTree.js +0 -84
- package/dist/IR/tree_utils/_ir_apps.d.ts +0 -3
- package/dist/IR/tree_utils/_ir_apps.js +0 -8
- package/dist/IR/tree_utils/_ir_lazyChooseList.d.ts +0 -3
- package/dist/IR/tree_utils/_ir_lazyChooseList.js +0 -5
- package/dist/IR/tree_utils/_ir_lazyIfThenElse.d.ts +0 -3
- package/dist/IR/tree_utils/_ir_lazyIfThenElse.js +0 -5
- package/dist/IR/tree_utils/_ir_let.d.ts +0 -3
- package/dist/IR/tree_utils/_ir_let.js +0 -4
- package/dist/IR/tree_utils/getChildren.d.ts +0 -2
- package/dist/IR/tree_utils/getChildren.js +0 -33
- package/dist/IR/tree_utils/getRoot.d.ts +0 -2
- package/dist/IR/tree_utils/getRoot.js +0 -6
- package/dist/IR/utils/MutArrayLike.d.ts +0 -5
- package/dist/IR/utils/MutArrayLike.js +0 -1
- package/dist/IR/utils/concatUint8Arr.d.ts +0 -1
- package/dist/IR/utils/concatUint8Arr.js +0 -11
- package/dist/IR/utils/equalIRTerm.d.ts +0 -12
- package/dist/IR/utils/equalIRTerm.js +0 -19
- package/dist/IR/utils/index.d.ts +0 -3
- package/dist/IR/utils/index.js +0 -3
- package/dist/IR/utils/isClosedIRTerm.d.ts +0 -2
- package/dist/IR/utils/isClosedIRTerm.js +0 -58
- package/dist/IR/utils/isIRParentTerm.d.ts +0 -12
- package/dist/IR/utils/isIRParentTerm.js +0 -26
- package/dist/IR/utils/isIRTerm.d.ts +0 -2
- package/dist/IR/utils/isIRTerm.js +0 -30
- package/dist/IR/utils/positiveIntAsBytes.d.ts +0 -5
- package/dist/IR/utils/positiveIntAsBytes.js +0 -27
- package/dist/IR/utils/showIR.d.ts +0 -43
- package/dist/IR/utils/showIR.js +0 -372
- package/dist/ast/PebbleAst.d.ts +0 -8
- package/dist/ast/PebbleAst.js +0 -15
- package/dist/ast/Source/Source.d.ts +0 -47
- package/dist/ast/Source/Source.js +0 -89
- package/dist/ast/Source/SourceRange.d.ts +0 -16
- package/dist/ast/Source/SourceRange.js +0 -49
- package/dist/ast/nodes/HasSourceRange.d.ts +0 -5
- package/dist/ast/nodes/HasSourceRange.js +0 -6
- package/dist/ast/nodes/common/Identifier.d.ts +0 -13
- package/dist/ast/nodes/common/Identifier.js +0 -20
- package/dist/ast/nodes/expr/CaseExpr.d.ts +0 -22
- package/dist/ast/nodes/expr/CaseExpr.js +0 -30
- package/dist/ast/nodes/expr/ElemAccessExpr.d.ts +0 -12
- package/dist/ast/nodes/expr/ElemAccessExpr.js +0 -13
- package/dist/ast/nodes/expr/IsExpr.d.ts +0 -1
- package/dist/ast/nodes/expr/IsExpr.js +0 -14
- package/dist/ast/nodes/expr/ParentesizedExpr.d.ts +0 -8
- package/dist/ast/nodes/expr/ParentesizedExpr.js +0 -8
- package/dist/ast/nodes/expr/PebbleExpr.d.ts +0 -18
- package/dist/ast/nodes/expr/PebbleExpr.js +0 -31
- package/dist/ast/nodes/expr/PropAccessExpr.d.ts +0 -28
- package/dist/ast/nodes/expr/PropAccessExpr.js +0 -46
- package/dist/ast/nodes/expr/TernaryExpr.d.ts +0 -10
- package/dist/ast/nodes/expr/TernaryExpr.js +0 -12
- package/dist/ast/nodes/expr/TypeConversionExpr.d.ts +0 -10
- package/dist/ast/nodes/expr/TypeConversionExpr.js +0 -11
- package/dist/ast/nodes/expr/binary/BinaryExpr.d.ts +0 -133
- package/dist/ast/nodes/expr/binary/BinaryExpr.js +0 -253
- package/dist/ast/nodes/expr/functions/ArrowKind.d.ts +0 -9
- package/dist/ast/nodes/expr/functions/ArrowKind.js +0 -11
- package/dist/ast/nodes/expr/functions/CallExpr.d.ts +0 -17
- package/dist/ast/nodes/expr/functions/CallExpr.js +0 -16
- package/dist/ast/nodes/expr/functions/FuncExpr.d.ts +0 -21
- package/dist/ast/nodes/expr/functions/FuncExpr.js +0 -21
- package/dist/ast/nodes/expr/litteral/LitArrExpr.d.ts +0 -8
- package/dist/ast/nodes/expr/litteral/LitArrExpr.js +0 -8
- package/dist/ast/nodes/expr/litteral/LitFalseExpr.d.ts +0 -6
- package/dist/ast/nodes/expr/litteral/LitFalseExpr.js +0 -6
- package/dist/ast/nodes/expr/litteral/LitHexBytesExpr.d.ts +0 -7
- package/dist/ast/nodes/expr/litteral/LitHexBytesExpr.js +0 -8
- package/dist/ast/nodes/expr/litteral/LitIntExpr.d.ts +0 -7
- package/dist/ast/nodes/expr/litteral/LitIntExpr.js +0 -8
- package/dist/ast/nodes/expr/litteral/LitNamedObjExpr.d.ts +0 -12
- package/dist/ast/nodes/expr/litteral/LitNamedObjExpr.js +0 -12
- package/dist/ast/nodes/expr/litteral/LitObjExpr.d.ts +0 -14
- package/dist/ast/nodes/expr/litteral/LitObjExpr.js +0 -10
- package/dist/ast/nodes/expr/litteral/LitStrExpr.d.ts +0 -7
- package/dist/ast/nodes/expr/litteral/LitStrExpr.js +0 -8
- package/dist/ast/nodes/expr/litteral/LitThisExpr.d.ts +0 -6
- package/dist/ast/nodes/expr/litteral/LitThisExpr.js +0 -6
- package/dist/ast/nodes/expr/litteral/LitTrueExpr.d.ts +0 -6
- package/dist/ast/nodes/expr/litteral/LitTrueExpr.js +0 -6
- package/dist/ast/nodes/expr/litteral/LitUndefExpr.d.ts +0 -6
- package/dist/ast/nodes/expr/litteral/LitUndefExpr.js +0 -6
- package/dist/ast/nodes/expr/litteral/LitVoidExpr.d.ts +0 -6
- package/dist/ast/nodes/expr/litteral/LitVoidExpr.js +0 -6
- package/dist/ast/nodes/expr/litteral/LitteralExpr.d.ts +0 -13
- package/dist/ast/nodes/expr/litteral/LitteralExpr.js +0 -24
- package/dist/ast/nodes/expr/unary/IUnaryExpression.d.ts +0 -4
- package/dist/ast/nodes/expr/unary/IUnaryExpression.js +0 -1
- package/dist/ast/nodes/expr/unary/NonNullExpr.d.ts +0 -8
- package/dist/ast/nodes/expr/unary/NonNullExpr.js +0 -8
- package/dist/ast/nodes/expr/unary/UnaryExclamation.d.ts +0 -9
- package/dist/ast/nodes/expr/unary/UnaryExclamation.js +0 -8
- package/dist/ast/nodes/expr/unary/UnaryMinus.d.ts +0 -9
- package/dist/ast/nodes/expr/unary/UnaryMinus.js +0 -8
- package/dist/ast/nodes/expr/unary/UnaryPlus.d.ts +0 -9
- package/dist/ast/nodes/expr/unary/UnaryPlus.js +0 -8
- package/dist/ast/nodes/expr/unary/UnaryPrefixExpr.d.ts +0 -14
- package/dist/ast/nodes/expr/unary/UnaryPrefixExpr.js +0 -27
- package/dist/ast/nodes/expr/unary/UnaryTilde.d.ts +0 -9
- package/dist/ast/nodes/expr/unary/UnaryTilde.js +0 -8
- package/dist/ast/nodes/statements/AssertStmt.d.ts +0 -15
- package/dist/ast/nodes/statements/AssertStmt.js +0 -14
- package/dist/ast/nodes/statements/AssignmentStmt.d.ts +0 -105
- package/dist/ast/nodes/statements/AssignmentStmt.js +0 -211
- package/dist/ast/nodes/statements/BlockStmt.d.ts +0 -8
- package/dist/ast/nodes/statements/BlockStmt.js +0 -8
- package/dist/ast/nodes/statements/BreakStmt.d.ts +0 -6
- package/dist/ast/nodes/statements/BreakStmt.js +0 -6
- package/dist/ast/nodes/statements/ContinueStmt.d.ts +0 -6
- package/dist/ast/nodes/statements/ContinueStmt.js +0 -6
- package/dist/ast/nodes/statements/DecrStmt.d.ts +0 -11
- package/dist/ast/nodes/statements/DecrStmt.js +0 -11
- package/dist/ast/nodes/statements/DoWhileStmt.d.ts +0 -10
- package/dist/ast/nodes/statements/DoWhileStmt.js +0 -10
- package/dist/ast/nodes/statements/EmptyStmt.d.ts +0 -6
- package/dist/ast/nodes/statements/EmptyStmt.js +0 -6
- package/dist/ast/nodes/statements/ExportImportStmt.d.ts +0 -15
- package/dist/ast/nodes/statements/ExportImportStmt.js +0 -15
- package/dist/ast/nodes/statements/ExportStarStmt.d.ts +0 -8
- package/dist/ast/nodes/statements/ExportStarStmt.js +0 -8
- package/dist/ast/nodes/statements/ExportStmt.d.ts +0 -13
- package/dist/ast/nodes/statements/ExportStmt.js +0 -13
- package/dist/ast/nodes/statements/ExprStmt.d.ts +0 -8
- package/dist/ast/nodes/statements/ExprStmt.js +0 -18
- package/dist/ast/nodes/statements/FailStmt.d.ts +0 -11
- package/dist/ast/nodes/statements/FailStmt.js +0 -10
- package/dist/ast/nodes/statements/ForOfStmt.d.ts +0 -16
- package/dist/ast/nodes/statements/ForOfStmt.js +0 -15
- package/dist/ast/nodes/statements/ForStmt.d.ts +0 -19
- package/dist/ast/nodes/statements/ForStmt.js +0 -19
- package/dist/ast/nodes/statements/IfStmt.d.ts +0 -11
- package/dist/ast/nodes/statements/IfStmt.js +0 -12
- package/dist/ast/nodes/statements/ImportStarStmt.d.ts +0 -15
- package/dist/ast/nodes/statements/ImportStarStmt.js +0 -15
- package/dist/ast/nodes/statements/ImportStmt.d.ts +0 -21
- package/dist/ast/nodes/statements/ImportStmt.js +0 -25
- package/dist/ast/nodes/statements/IncrStmt.d.ts +0 -8
- package/dist/ast/nodes/statements/IncrStmt.js +0 -8
- package/dist/ast/nodes/statements/MatchStmt.d.ts +0 -17
- package/dist/ast/nodes/statements/MatchStmt.js +0 -20
- package/dist/ast/nodes/statements/PebbleStmt.d.ts +0 -29
- package/dist/ast/nodes/statements/PebbleStmt.js +0 -62
- package/dist/ast/nodes/statements/ReturnStmt.d.ts +0 -8
- package/dist/ast/nodes/statements/ReturnStmt.js +0 -8
- package/dist/ast/nodes/statements/TestStmt.d.ts +0 -10
- package/dist/ast/nodes/statements/TestStmt.js +0 -10
- package/dist/ast/nodes/statements/TypeImplementsStmt.d.ts +0 -21
- package/dist/ast/nodes/statements/TypeImplementsStmt.js +0 -26
- package/dist/ast/nodes/statements/UsingStmt.d.ts +0 -16
- package/dist/ast/nodes/statements/UsingStmt.js +0 -20
- package/dist/ast/nodes/statements/VarStmt.d.ts +0 -10
- package/dist/ast/nodes/statements/VarStmt.js +0 -11
- package/dist/ast/nodes/statements/WhileStmt.d.ts +0 -10
- package/dist/ast/nodes/statements/WhileStmt.js +0 -10
- package/dist/ast/nodes/statements/declarations/EnumDecl.d.ts +0 -18
- package/dist/ast/nodes/statements/declarations/EnumDecl.js +0 -22
- package/dist/ast/nodes/statements/declarations/FuncDecl.d.ts +0 -8
- package/dist/ast/nodes/statements/declarations/FuncDecl.js +0 -9
- package/dist/ast/nodes/statements/declarations/InterfaceDecl.d.ts +0 -19
- package/dist/ast/nodes/statements/declarations/InterfaceDecl.js +0 -26
- package/dist/ast/nodes/statements/declarations/PebbleTypeDecl.d.ts +0 -5
- package/dist/ast/nodes/statements/declarations/PebbleTypeDecl.js +0 -8
- package/dist/ast/nodes/statements/declarations/StructDecl.d.ts +0 -25
- package/dist/ast/nodes/statements/declarations/StructDecl.js +0 -36
- package/dist/ast/nodes/statements/declarations/TypeAliasDecl.d.ts +0 -11
- package/dist/ast/nodes/statements/declarations/TypeAliasDecl.js +0 -12
- package/dist/ast/nodes/statements/declarations/VarDecl/ArrayLikeDeconstr.d.ts +0 -19
- package/dist/ast/nodes/statements/declarations/VarDecl/ArrayLikeDeconstr.js +0 -19
- package/dist/ast/nodes/statements/declarations/VarDecl/HasInit.d.ts +0 -5
- package/dist/ast/nodes/statements/declarations/VarDecl/HasInit.js +0 -7
- package/dist/ast/nodes/statements/declarations/VarDecl/NamedDeconstructVarDecl.d.ts +0 -24
- package/dist/ast/nodes/statements/declarations/VarDecl/NamedDeconstructVarDecl.js +0 -30
- package/dist/ast/nodes/statements/declarations/VarDecl/SimpleVarDecl.d.ts +0 -17
- package/dist/ast/nodes/statements/declarations/VarDecl/SimpleVarDecl.js +0 -21
- package/dist/ast/nodes/statements/declarations/VarDecl/SingleDeconstructVarDecl.d.ts +0 -24
- package/dist/ast/nodes/statements/declarations/VarDecl/SingleDeconstructVarDecl.js +0 -20
- package/dist/ast/nodes/statements/declarations/VarDecl/VarDecl.d.ts +0 -8
- package/dist/ast/nodes/statements/declarations/VarDecl/VarDecl.js +0 -13
- package/dist/ast/nodes/types/AstNamedTypeExpr.d.ts +0 -14
- package/dist/ast/nodes/types/AstNamedTypeExpr.js +0 -14
- package/dist/ast/nodes/types/AstNativeTypeExpr.d.ts +0 -52
- package/dist/ast/nodes/types/AstNativeTypeExpr.js +0 -82
- package/dist/ast/nodes/types/AstTypeExpr.d.ts +0 -4
- package/dist/ast/nodes/types/AstTypeExpr.js +0 -7
- package/dist/common.d.ts +0 -194
- package/dist/common.js +0 -224
- package/dist/compiler/AstCompiler/AstCompilationCtx.d.ts +0 -35
- package/dist/compiler/AstCompiler/AstCompilationCtx.js +0 -43
- package/dist/compiler/AstCompiler/AstCompiler.d.ts +0 -73
- package/dist/compiler/AstCompiler/AstCompiler.js +0 -532
- package/dist/compiler/AstCompiler/compileAst.d.ts +0 -0
- package/dist/compiler/AstCompiler/compileAst.js +0 -0
- package/dist/compiler/AstCompiler/index.d.ts +0 -1
- package/dist/compiler/AstCompiler/index.js +0 -1
- package/dist/compiler/AstCompiler/internal/exprs/_compileBinaryExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileBinaryExpr.js +0 -66
- package/dist/compiler/AstCompiler/internal/exprs/_compileCallExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileCallExpr.js +0 -36
- package/dist/compiler/AstCompiler/internal/exprs/_compileCaseExpr.d.ts +0 -6
- package/dist/compiler/AstCompiler/internal/exprs/_compileCaseExpr.js +0 -47
- package/dist/compiler/AstCompiler/internal/exprs/_compileElemAccessExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileElemAccessExpr.js +0 -23
- package/dist/compiler/AstCompiler/internal/exprs/_compileExpr.d.ts +0 -22
- package/dist/compiler/AstCompiler/internal/exprs/_compileExpr.js +0 -77
- package/dist/compiler/AstCompiler/internal/exprs/_compileFuncExpr.d.ts +0 -26
- package/dist/compiler/AstCompiler/internal/exprs/_compileFuncExpr.js +0 -163
- package/dist/compiler/AstCompiler/internal/exprs/_compileIsExpr.d.ts +0 -1
- package/dist/compiler/AstCompiler/internal/exprs/_compileIsExpr.js +0 -43
- package/dist/compiler/AstCompiler/internal/exprs/_compileLitteralExpr.d.ts +0 -19
- package/dist/compiler/AstCompiler/internal/exprs/_compileLitteralExpr.js +0 -202
- package/dist/compiler/AstCompiler/internal/exprs/_compileNonNullExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileNonNullExpr.js +0 -43
- package/dist/compiler/AstCompiler/internal/exprs/_compilePropAccessExpr.d.ts +0 -9
- package/dist/compiler/AstCompiler/internal/exprs/_compilePropAccessExpr.js +0 -102
- package/dist/compiler/AstCompiler/internal/exprs/_compileTernaryExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileTernaryExpr.js +0 -22
- package/dist/compiler/AstCompiler/internal/exprs/_compileTypeConversionExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileTypeConversionExpr.js +0 -25
- package/dist/compiler/AstCompiler/internal/exprs/_compileUnaryPrefixExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileUnaryPrefixExpr.js +0 -54
- package/dist/compiler/AstCompiler/internal/exprs/_compileVarAccessExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/_compileVarAccessExpr.js +0 -9
- package/dist/compiler/AstCompiler/internal/exprs/_hasDuplicateTypeParams.d.ts +0 -3
- package/dist/compiler/AstCompiler/internal/exprs/_hasDuplicateTypeParams.js +0 -13
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileAddExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileAddExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileBitwiseAndExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileBitwiseAndExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileBitwiseOrExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileBitwiseOrExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileBitwiseXorExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileBitwiseXorExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileDivExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileDivExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileEqualExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileEqualExpr.js +0 -18
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileExponentiationExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileExponentiationExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileGreaterThanEqualExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileGreaterThanEqualExpr.js +0 -27
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileGreaterThanExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileGreaterThanExpr.js +0 -26
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLessThanEqualExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLessThanEqualExpr.js +0 -25
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLessThanExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLessThanExpr.js +0 -26
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLogicalAndExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLogicalAndExpr.js +0 -22
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLogicalOrExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileLogicalOrExpr.js +0 -22
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileModuloExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileModuloExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileMultExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileMultExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileNotEqualExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileNotEqualExpr.js +0 -18
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileOptionalDefaultExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileOptionalDefaultExpr.js +0 -60
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileShiftLeftExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileShiftLeftExpr.js +0 -21
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileShiftRightExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileShiftRightExpr.js +0 -21
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileSubExpr.d.ts +0 -5
- package/dist/compiler/AstCompiler/internal/exprs/binary/_compileSubExpr.js +0 -20
- package/dist/compiler/AstCompiler/internal/statements/_compileAssertStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileAssertStmt.js +0 -30
- package/dist/compiler/AstCompiler/internal/statements/_compileAssignmentStmt.d.ts +0 -8
- package/dist/compiler/AstCompiler/internal/statements/_compileAssignmentStmt.js +0 -154
- package/dist/compiler/AstCompiler/internal/statements/_compileBlockStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileBlockStmt.js +0 -14
- package/dist/compiler/AstCompiler/internal/statements/_compileBreakStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileBreakStmt.js +0 -7
- package/dist/compiler/AstCompiler/internal/statements/_compileContinueStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileContinueStmt.js +0 -7
- package/dist/compiler/AstCompiler/internal/statements/_compileExprStmt.d.ts +0 -1
- package/dist/compiler/AstCompiler/internal/statements/_compileExprStmt.js +0 -12
- package/dist/compiler/AstCompiler/internal/statements/_compileFailStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileFailStmt.js +0 -18
- package/dist/compiler/AstCompiler/internal/statements/_compileForOfStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileForOfStmt.js +0 -30
- package/dist/compiler/AstCompiler/internal/statements/_compileForStmt.d.ts +0 -7
- package/dist/compiler/AstCompiler/internal/statements/_compileForStmt.js +0 -46
- package/dist/compiler/AstCompiler/internal/statements/_compileIfStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileIfStmt.js +0 -27
- package/dist/compiler/AstCompiler/internal/statements/_compileMatchStmt.d.ts +0 -6
- package/dist/compiler/AstCompiler/internal/statements/_compileMatchStmt.js +0 -182
- package/dist/compiler/AstCompiler/internal/statements/_compileReturnStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileReturnStmt.js +0 -17
- package/dist/compiler/AstCompiler/internal/statements/_compileStatement.d.ts +0 -11
- package/dist/compiler/AstCompiler/internal/statements/_compileStatement.js +0 -73
- package/dist/compiler/AstCompiler/internal/statements/_compileTestStmt.d.ts +0 -1
- package/dist/compiler/AstCompiler/internal/statements/_compileTestStmt.js +0 -32
- package/dist/compiler/AstCompiler/internal/statements/_compileUsingStmt.d.ts +0 -11
- package/dist/compiler/AstCompiler/internal/statements/_compileUsingStmt.js +0 -41
- package/dist/compiler/AstCompiler/internal/statements/_compileVarStmt.d.ts +0 -34
- package/dist/compiler/AstCompiler/internal/statements/_compileVarStmt.js +0 -207
- package/dist/compiler/AstCompiler/internal/statements/_compileWhileStmt.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/statements/_compileWhileStmt.js +0 -19
- package/dist/compiler/AstCompiler/internal/types/_compileDataEncodedConcreteType.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/types/_compileDataEncodedConcreteType.js +0 -61
- package/dist/compiler/AstCompiler/internal/types/_compileSopEncodedConcreteType.d.ts +0 -4
- package/dist/compiler/AstCompiler/internal/types/_compileSopEncodedConcreteType.js +0 -59
- package/dist/compiler/AstCompiler/scope/AstScope.d.ts +0 -102
- package/dist/compiler/AstCompiler/scope/AstScope.js +0 -195
- package/dist/compiler/AstCompiler/utils/deps/ResolveStackNode.d.ts +0 -14
- package/dist/compiler/AstCompiler/utils/deps/ResolveStackNode.js +0 -36
- package/dist/compiler/AstCompiler/utils/getPropAccessReturnType.d.ts +0 -4
- package/dist/compiler/AstCompiler/utils/getPropAccessReturnType.js +0 -121
- package/dist/compiler/AstCompiler/utils/getTirFuncSigTree/TirFuncSigTree.d.ts +0 -39
- package/dist/compiler/AstCompiler/utils/getTirFuncSigTree/TirFuncSigTree.js +0 -129
- package/dist/compiler/AstCompiler/utils/getTirFuncSigTree/getTirFuncSigTree.d.ts +0 -4
- package/dist/compiler/AstCompiler/utils/getTirFuncSigTree/getTirFuncSigTree.js +0 -49
- package/dist/compiler/AstCompiler/utils/wrapManyStatementsOrReturnSame.d.ts +0 -3
- package/dist/compiler/AstCompiler/utils/wrapManyStatementsOrReturnSame.js +0 -12
- package/dist/compiler/Compiler.d.ts +0 -10
- package/dist/compiler/Compiler.js +0 -39
- package/dist/compiler/TirCompiler/TirCompilerCtx.d.ts +0 -7
- package/dist/compiler/TirCompiler/TirCompilerCtx.js +0 -8
- package/dist/compiler/TirCompiler/compileTirProgram.d.ts +0 -9
- package/dist/compiler/TirCompiler/compileTirProgram.js +0 -18
- package/dist/compiler/TirCompiler/expressify/ExpressifyCtx.d.ts +0 -72
- package/dist/compiler/TirCompiler/expressify/ExpressifyCtx.js +0 -282
- package/dist/compiler/TirCompiler/expressify/determineReassignedVariablesAndReturn.d.ts +0 -27
- package/dist/compiler/TirCompiler/expressify/determineReassignedVariablesAndReturn.js +0 -248
- package/dist/compiler/TirCompiler/expressify/expressify.d.ts +0 -15
- package/dist/compiler/TirCompiler/expressify/expressify.js +0 -403
- package/dist/compiler/TirCompiler/expressify/expressifyForStmt.d.ts +0 -8
- package/dist/compiler/TirCompiler/expressify/expressifyForStmt.js +0 -115
- package/dist/compiler/TirCompiler/expressify/expressifyIfBranch.d.ts +0 -6
- package/dist/compiler/TirCompiler/expressify/expressifyIfBranch.js +0 -105
- package/dist/compiler/TirCompiler/expressify/expressifyTerminatingIfStmt.d.ts +0 -5
- package/dist/compiler/TirCompiler/expressify/expressifyTerminatingIfStmt.js +0 -15
- package/dist/compiler/TirCompiler/expressify/expressifyVarAssignmentStmt.d.ts +0 -4
- package/dist/compiler/TirCompiler/expressify/expressifyVarAssignmentStmt.js +0 -20
- package/dist/compiler/TirCompiler/expressify/expressifyVarDecl.d.ts +0 -3
- package/dist/compiler/TirCompiler/expressify/expressifyVarDecl.js +0 -34
- package/dist/compiler/TirCompiler/expressify/expressifyVars.d.ts +0 -10
- package/dist/compiler/TirCompiler/expressify/expressifyVars.js +0 -320
- package/dist/compiler/TirCompiler/expressify/flattenSopNamedDeconstructInplace_addTopDestructToCtx_getNestedDeconstruct.d.ts +0 -9
- package/dist/compiler/TirCompiler/expressify/flattenSopNamedDeconstructInplace_addTopDestructToCtx_getNestedDeconstruct.js +0 -59
- package/dist/compiler/TirCompiler/expressify/isSingleConstrStruct.d.ts +0 -3
- package/dist/compiler/TirCompiler/expressify/isSingleConstrStruct.js +0 -9
- package/dist/compiler/TirCompiler/expressify/toNamedDeconstructVarDecl.d.ts +0 -3
- package/dist/compiler/TirCompiler/expressify/toNamedDeconstructVarDecl.js +0 -15
- package/dist/compiler/TirCompiler/index.d.ts +0 -2
- package/dist/compiler/TirCompiler/index.js +0 -2
- package/dist/compiler/TirCompiler/internal/_compileHoistedDeps.d.ts +0 -5
- package/dist/compiler/TirCompiler/internal/_compileHoistedDeps.js +0 -37
- package/dist/compiler/TirCompiler/internal/deps/DepsNode.d.ts +0 -13
- package/dist/compiler/TirCompiler/internal/deps/DepsNode.js +0 -36
- package/dist/compiler/index.d.ts +0 -4
- package/dist/compiler/index.js +0 -4
- package/dist/compiler/internalVar.d.ts +0 -19
- package/dist/compiler/internalVar.js +0 -56
- package/dist/compiler/io/CompilerIoApi.d.ts +0 -36
- package/dist/compiler/io/CompilerIoApi.js +0 -62
- package/dist/compiler/io/IOutputStream.d.ts +0 -28
- package/dist/compiler/io/IOutputStream.js +0 -45
- package/dist/compiler/io/index.d.ts +0 -2
- package/dist/compiler/io/index.js +0 -2
- package/dist/compiler/path/getAbsolutePath.d.ts +0 -12
- package/dist/compiler/path/getAbsolutePath.js +0 -114
- package/dist/compiler/path/path.d.ts +0 -5
- package/dist/compiler/path/path.js +0 -160
- package/dist/compiler/tir/expressions/ITirExpr.d.ts +0 -11
- package/dist/compiler/tir/expressions/ITirExpr.js +0 -1
- package/dist/compiler/tir/expressions/TirAssertAndContinueExpr.d.ts +0 -19
- package/dist/compiler/tir/expressions/TirAssertAndContinueExpr.js +0 -41
- package/dist/compiler/tir/expressions/TirCallExpr.d.ts +0 -17
- package/dist/compiler/tir/expressions/TirCallExpr.js +0 -28
- package/dist/compiler/tir/expressions/TirCaseExpr.d.ts +0 -36
- package/dist/compiler/tir/expressions/TirCaseExpr.js +0 -257
- package/dist/compiler/tir/expressions/TirElemAccessExpr.d.ts +0 -20
- package/dist/compiler/tir/expressions/TirElemAccessExpr.js +0 -43
- package/dist/compiler/tir/expressions/TirExpr.d.ts +0 -23
- package/dist/compiler/tir/expressions/TirExpr.js +0 -46
- package/dist/compiler/tir/expressions/TirFailExpr.d.ts +0 -19
- package/dist/compiler/tir/expressions/TirFailExpr.js +0 -28
- package/dist/compiler/tir/expressions/TirFromDataExpr.d.ts +0 -22
- package/dist/compiler/tir/expressions/TirFromDataExpr.js +0 -196
- package/dist/compiler/tir/expressions/TirFuncExpr.d.ts +0 -37
- package/dist/compiler/tir/expressions/TirFuncExpr.js +0 -92
- package/dist/compiler/tir/expressions/TirHoistedExpr.d.ts +0 -18
- package/dist/compiler/tir/expressions/TirHoistedExpr.js +0 -28
- package/dist/compiler/tir/expressions/TirInlineClosedIR.d.ts +0 -16
- package/dist/compiler/tir/expressions/TirInlineClosedIR.js +0 -25
- package/dist/compiler/tir/expressions/TirLettedExpr.d.ts +0 -18
- package/dist/compiler/tir/expressions/TirLettedExpr.js +0 -28
- package/dist/compiler/tir/expressions/TirNativeFunc.d.ts +0 -104
- package/dist/compiler/tir/expressions/TirNativeFunc.js +0 -805
- package/dist/compiler/tir/expressions/TirParentesizedExpr.d.ts +0 -17
- package/dist/compiler/tir/expressions/TirParentesizedExpr.js +0 -20
- package/dist/compiler/tir/expressions/TirPropAccessExpr.d.ts +0 -18
- package/dist/compiler/tir/expressions/TirPropAccessExpr.js +0 -29
- package/dist/compiler/tir/expressions/TirTernaryExpr.d.ts +0 -18
- package/dist/compiler/tir/expressions/TirTernaryExpr.js +0 -36
- package/dist/compiler/tir/expressions/TirToDataExpr.d.ts +0 -28
- package/dist/compiler/tir/expressions/TirToDataExpr.js +0 -172
- package/dist/compiler/tir/expressions/TirTraceIfFalseExpr.d.ts +0 -23
- package/dist/compiler/tir/expressions/TirTraceIfFalseExpr.js +0 -32
- package/dist/compiler/tir/expressions/TirTypeConversionExpr.d.ts +0 -16
- package/dist/compiler/tir/expressions/TirTypeConversionExpr.js +0 -66
- package/dist/compiler/tir/expressions/TirVariableAccessExpr.d.ts +0 -18
- package/dist/compiler/tir/expressions/TirVariableAccessExpr.js +0 -30
- package/dist/compiler/tir/expressions/ToIRTermCtx.d.ts +0 -29
- package/dist/compiler/tir/expressions/ToIRTermCtx.js +0 -77
- package/dist/compiler/tir/expressions/binary/TirBinaryExpr.d.ts +0 -221
- package/dist/compiler/tir/expressions/binary/TirBinaryExpr.js +0 -532
- package/dist/compiler/tir/expressions/litteral/TirLitArrExpr.d.ts +0 -16
- package/dist/compiler/tir/expressions/litteral/TirLitArrExpr.js +0 -60
- package/dist/compiler/tir/expressions/litteral/TirLitFalseExpr.d.ts +0 -14
- package/dist/compiler/tir/expressions/litteral/TirLitFalseExpr.js +0 -17
- package/dist/compiler/tir/expressions/litteral/TirLitHexBytesExpr.d.ts +0 -15
- package/dist/compiler/tir/expressions/litteral/TirLitHexBytesExpr.js +0 -19
- package/dist/compiler/tir/expressions/litteral/TirLitIntExpr.d.ts +0 -15
- package/dist/compiler/tir/expressions/litteral/TirLitIntExpr.js +0 -19
- package/dist/compiler/tir/expressions/litteral/TirLitNamedObjExpr.d.ts +0 -22
- package/dist/compiler/tir/expressions/litteral/TirLitNamedObjExpr.js +0 -105
- package/dist/compiler/tir/expressions/litteral/TirLitObjExpr.d.ts +0 -22
- package/dist/compiler/tir/expressions/litteral/TirLitObjExpr.js +0 -102
- package/dist/compiler/tir/expressions/litteral/TirLitStrExpr.d.ts +0 -15
- package/dist/compiler/tir/expressions/litteral/TirLitStrExpr.js +0 -20
- package/dist/compiler/tir/expressions/litteral/TirLitThisExpr.d.ts +0 -14
- package/dist/compiler/tir/expressions/litteral/TirLitThisExpr.js +0 -20
- package/dist/compiler/tir/expressions/litteral/TirLitTrueExpr.d.ts +0 -14
- package/dist/compiler/tir/expressions/litteral/TirLitTrueExpr.js +0 -17
- package/dist/compiler/tir/expressions/litteral/TirLitUndefExpr.d.ts +0 -18
- package/dist/compiler/tir/expressions/litteral/TirLitUndefExpr.js +0 -23
- package/dist/compiler/tir/expressions/litteral/TirLitVoidExpr.d.ts +0 -14
- package/dist/compiler/tir/expressions/litteral/TirLitVoidExpr.js +0 -17
- package/dist/compiler/tir/expressions/litteral/TirLitteralExpr.d.ts +0 -13
- package/dist/compiler/tir/expressions/litteral/TirLitteralExpr.js +0 -24
- package/dist/compiler/tir/expressions/unary/ITirUnaryExpression.d.ts +0 -4
- package/dist/compiler/tir/expressions/unary/ITirUnaryExpression.js +0 -1
- package/dist/compiler/tir/expressions/unary/TirUnaryExclamation.d.ts +0 -17
- package/dist/compiler/tir/expressions/unary/TirUnaryExclamation.js +0 -23
- package/dist/compiler/tir/expressions/unary/TirUnaryMinus.d.ts +0 -17
- package/dist/compiler/tir/expressions/unary/TirUnaryMinus.js +0 -22
- package/dist/compiler/tir/expressions/unary/TirUnaryPlus.d.ts +0 -15
- package/dist/compiler/tir/expressions/unary/TirUnaryPlus.js +0 -20
- package/dist/compiler/tir/expressions/unary/TirUnaryPrefixExpr.d.ts +0 -6
- package/dist/compiler/tir/expressions/unary/TirUnaryPrefixExpr.js +0 -10
- package/dist/compiler/tir/expressions/unary/TirUnaryTilde.d.ts +0 -17
- package/dist/compiler/tir/expressions/unary/TirUnaryTilde.js +0 -22
- package/dist/compiler/tir/expressions/utils/NamedExpr.d.ts +0 -5
- package/dist/compiler/tir/expressions/utils/NamedExpr.js +0 -1
- package/dist/compiler/tir/program/TypedProgram.d.ts +0 -44
- package/dist/compiler/tir/program/TypedProgram.js +0 -126
- package/dist/compiler/tir/program/stdScope/StdTypes.d.ts +0 -34
- package/dist/compiler/tir/program/stdScope/StdTypes.js +0 -40
- package/dist/compiler/tir/program/stdScope/prelude/preludeTypesSrc.d.ts +0 -0
- package/dist/compiler/tir/program/stdScope/prelude/preludeTypesSrc.js +0 -288
- package/dist/compiler/tir/program/stdScope/stdScope.d.ts +0 -15
- package/dist/compiler/tir/program/stdScope/stdScope.js +0 -730
- package/dist/compiler/tir/statements/TirAssertStmt.d.ts +0 -18
- package/dist/compiler/tir/statements/TirAssertStmt.js +0 -29
- package/dist/compiler/tir/statements/TirAssignmentStmt.d.ts +0 -12
- package/dist/compiler/tir/statements/TirAssignmentStmt.js +0 -14
- package/dist/compiler/tir/statements/TirBlockStmt.d.ts +0 -9
- package/dist/compiler/tir/statements/TirBlockStmt.js +0 -25
- package/dist/compiler/tir/statements/TirBreakStmt.d.ts +0 -8
- package/dist/compiler/tir/statements/TirBreakStmt.js +0 -11
- package/dist/compiler/tir/statements/TirContinueStmt.d.ts +0 -8
- package/dist/compiler/tir/statements/TirContinueStmt.js +0 -13
- package/dist/compiler/tir/statements/TirFailStmt.d.ts +0 -13
- package/dist/compiler/tir/statements/TirFailStmt.js +0 -14
- package/dist/compiler/tir/statements/TirForOfStmt.d.ts +0 -16
- package/dist/compiler/tir/statements/TirForOfStmt.js +0 -25
- package/dist/compiler/tir/statements/TirForStmt.d.ts +0 -19
- package/dist/compiler/tir/statements/TirForStmt.js +0 -39
- package/dist/compiler/tir/statements/TirIfStmt.d.ts +0 -12
- package/dist/compiler/tir/statements/TirIfStmt.js +0 -23
- package/dist/compiler/tir/statements/TirMatchStmt.d.ts +0 -27
- package/dist/compiler/tir/statements/TirMatchStmt.js +0 -51
- package/dist/compiler/tir/statements/TirReturnStmt.d.ts +0 -10
- package/dist/compiler/tir/statements/TirReturnStmt.js +0 -12
- package/dist/compiler/tir/statements/TirStmt.d.ts +0 -32
- package/dist/compiler/tir/statements/TirStmt.js +0 -40
- package/dist/compiler/tir/statements/TirVarDecl/TirArrayLikeDeconstr.d.ts +0 -17
- package/dist/compiler/tir/statements/TirVarDecl/TirArrayLikeDeconstr.js +0 -30
- package/dist/compiler/tir/statements/TirVarDecl/TirNamedDeconstructVarDecl.d.ts +0 -21
- package/dist/compiler/tir/statements/TirVarDecl/TirNamedDeconstructVarDecl.js +0 -34
- package/dist/compiler/tir/statements/TirVarDecl/TirSimpleVarDecl.d.ts +0 -17
- package/dist/compiler/tir/statements/TirVarDecl/TirSimpleVarDecl.js +0 -22
- package/dist/compiler/tir/statements/TirVarDecl/TirSingleDeconstructVarDecl.d.ts +0 -17
- package/dist/compiler/tir/statements/TirVarDecl/TirSingleDeconstructVarDecl.js +0 -30
- package/dist/compiler/tir/statements/TirVarDecl/TirVarDecl.d.ts +0 -10
- package/dist/compiler/tir/statements/TirVarDecl/TirVarDecl.js +0 -11
- package/dist/compiler/tir/statements/TirWhileStmt.d.ts +0 -11
- package/dist/compiler/tir/statements/TirWhileStmt.js +0 -19
- package/dist/compiler/tir/statements/utils/definitelyFails.d.ts +0 -3
- package/dist/compiler/tir/statements/utils/definitelyFails.js +0 -52
- package/dist/compiler/tir/types/TirAliasType.d.ts +0 -32
- package/dist/compiler/tir/types/TirAliasType.js +0 -49
- package/dist/compiler/tir/types/TirInterfaceImpl.d.ts +0 -44
- package/dist/compiler/tir/types/TirInterfaceImpl.js +0 -32
- package/dist/compiler/tir/types/TirInterfaceType.d.ts +0 -28
- package/dist/compiler/tir/types/TirInterfaceType.js +0 -36
- package/dist/compiler/tir/types/TirNativeType/TirNativeType.d.ts +0 -41
- package/dist/compiler/tir/types/TirNativeType/TirNativeType.js +0 -86
- package/dist/compiler/tir/types/TirNativeType/index.d.ts +0 -2
- package/dist/compiler/tir/types/TirNativeType/index.js +0 -2
- package/dist/compiler/tir/types/TirNativeType/native/Optional/data.d.ts +0 -17
- package/dist/compiler/tir/types/TirNativeType/native/Optional/data.js +0 -47
- package/dist/compiler/tir/types/TirNativeType/native/Optional/index.d.ts +0 -3
- package/dist/compiler/tir/types/TirNativeType/native/Optional/index.js +0 -3
- package/dist/compiler/tir/types/TirNativeType/native/Optional/isTirOptType.d.ts +0 -4
- package/dist/compiler/tir/types/TirNativeType/native/Optional/isTirOptType.js +0 -6
- package/dist/compiler/tir/types/TirNativeType/native/Optional/sop.d.ts +0 -17
- package/dist/compiler/tir/types/TirNativeType/native/Optional/sop.js +0 -48
- package/dist/compiler/tir/types/TirNativeType/native/bool.d.ts +0 -13
- package/dist/compiler/tir/types/TirNativeType/native/bool.js +0 -12
- package/dist/compiler/tir/types/TirNativeType/native/bytes.d.ts +0 -13
- package/dist/compiler/tir/types/TirNativeType/native/bytes.js +0 -12
- package/dist/compiler/tir/types/TirNativeType/native/data.d.ts +0 -13
- package/dist/compiler/tir/types/TirNativeType/native/data.js +0 -12
- package/dist/compiler/tir/types/TirNativeType/native/function.d.ts +0 -16
- package/dist/compiler/tir/types/TirNativeType/native/function.js +0 -38
- package/dist/compiler/tir/types/TirNativeType/native/index.d.ts +0 -10
- package/dist/compiler/tir/types/TirNativeType/native/index.js +0 -10
- package/dist/compiler/tir/types/TirNativeType/native/int.d.ts +0 -13
- package/dist/compiler/tir/types/TirNativeType/native/int.js +0 -12
- package/dist/compiler/tir/types/TirNativeType/native/linearMap.d.ts +0 -17
- package/dist/compiler/tir/types/TirNativeType/native/linearMap.js +0 -44
- package/dist/compiler/tir/types/TirNativeType/native/list.d.ts +0 -16
- package/dist/compiler/tir/types/TirNativeType/native/list.js +0 -38
- package/dist/compiler/tir/types/TirNativeType/native/string.d.ts +0 -13
- package/dist/compiler/tir/types/TirNativeType/native/string.js +0 -12
- package/dist/compiler/tir/types/TirNativeType/native/void.d.ts +0 -13
- package/dist/compiler/tir/types/TirNativeType/native/void.js +0 -12
- package/dist/compiler/tir/types/TirStructType.d.ts +0 -68
- package/dist/compiler/tir/types/TirStructType.js +0 -128
- package/dist/compiler/tir/types/TirType.d.ts +0 -34
- package/dist/compiler/tir/types/TirType.js +0 -16
- package/dist/compiler/tir/types/TirTypeParam.d.ts +0 -18
- package/dist/compiler/tir/types/TirTypeParam.js +0 -39
- package/dist/compiler/tir/types/utils/canAssignTo.d.ts +0 -24
- package/dist/compiler/tir/types/utils/canAssignTo.js +0 -337
- package/dist/compiler/tir/types/utils/canCastTo.d.ts +0 -9
- package/dist/compiler/tir/types/utils/canCastTo.js +0 -155
- package/dist/compiler/tir/types/utils/getDeconstructableType.d.ts +0 -9
- package/dist/compiler/tir/types/utils/getDeconstructableType.js +0 -20
- package/dist/compiler/tir/types/utils/getListTypeArg.d.ts +0 -2
- package/dist/compiler/tir/types/utils/getListTypeArg.js +0 -9
- package/dist/compiler/tir/types/utils/getOptTypeArg.d.ts +0 -2
- package/dist/compiler/tir/types/utils/getOptTypeArg.js +0 -14
- package/dist/compiler/tir/types/utils/getUnaliased.d.ts +0 -3
- package/dist/compiler/tir/types/utils/getUnaliased.js +0 -9
- package/dist/diagnostics/DiagnosticCategory.d.ts +0 -16
- package/dist/diagnostics/DiagnosticCategory.js +0 -39
- package/dist/diagnostics/DiagnosticEmitter.d.ts +0 -32
- package/dist/diagnostics/DiagnosticEmitter.js +0 -95
- package/dist/diagnostics/DiagnosticMessage.d.ts +0 -37
- package/dist/diagnostics/DiagnosticMessage.js +0 -229
- package/dist/diagnostics/diagnosticMessages.generated.d.ts +0 -275
- package/dist/diagnostics/diagnosticMessages.generated.js +0 -551
- package/dist/diagnostics/utils/types.d.ts +0 -5
- package/dist/diagnostics/utils/types.js +0 -1
- package/dist/index.d.ts +0 -12
- package/dist/index.js +0 -13
- package/dist/parser/Parser.d.ts +0 -150
- package/dist/parser/Parser.js +0 -2416
- package/dist/parser/Precedence.d.ts +0 -38
- package/dist/parser/Precedence.js +0 -98
- package/dist/parser/hoistStatementsInplace.d.ts +0 -14
- package/dist/parser/hoistStatementsInplace.js +0 -94
- package/dist/parser/index.d.ts +0 -1
- package/dist/parser/index.js +0 -1
- package/dist/parser/parseFile.d.ts +0 -3
- package/dist/parser/parseFile.js +0 -8
- package/dist/tokenizer/IdentifierHandling.d.ts +0 -5
- package/dist/tokenizer/IdentifierHandling.js +0 -6
- package/dist/tokenizer/OnNewLine.d.ts +0 -6
- package/dist/tokenizer/OnNewLine.js +0 -8
- package/dist/tokenizer/Token.d.ts +0 -160
- package/dist/tokenizer/Token.js +0 -213
- package/dist/tokenizer/Tokenizer.d.ts +0 -129
- package/dist/tokenizer/Tokenizer.js +0 -1323
- package/dist/tokenizer/TokenizerState.d.ts +0 -17
- package/dist/tokenizer/TokenizerState.js +0 -17
- package/dist/tokenizer/index.d.ts +0 -2
- package/dist/tokenizer/index.js +0 -2
- package/dist/tokenizer/utils/isIllegalVariableIdentifier.d.ts +0 -1
- package/dist/tokenizer/utils/isIllegalVariableIdentifier.js +0 -12
- package/dist/tokenizer/utils/operatorTokenToString.d.ts +0 -2
- package/dist/tokenizer/utils/operatorTokenToString.js +0 -57
- package/dist/tokenizer/utils/tokenFromKeyword.d.ts +0 -2
- package/dist/tokenizer/utils/tokenFromKeyword.js +0 -222
- package/dist/tokenizer/utils/tokenIsAlsoIdentifier.d.ts +0 -2
- package/dist/tokenizer/utils/tokenIsAlsoIdentifier.js +0 -24
- package/dist/utils/BasePlutsError.d.ts +0 -2
- package/dist/utils/BasePlutsError.js +0 -2
- package/dist/utils/BitUtils/index.d.ts +0 -30
- package/dist/utils/BitUtils/index.js +0 -60
- package/dist/utils/CharCode.d.ts +0 -125
- package/dist/utils/CharCode.js +0 -1
- package/dist/utils/Cloneable.d.ts +0 -6
- package/dist/utils/Cloneable.js +0 -4
- package/dist/utils/InvalidCborFormatError.d.ts +0 -3
- package/dist/utils/InvalidCborFormatError.js +0 -5
- package/dist/utils/IsSingleKey.d.ts +0 -7
- package/dist/utils/IsSingleKey.js +0 -1
- package/dist/utils/MaybePromise.d.ts +0 -2
- package/dist/utils/MaybePromise.js +0 -4
- package/dist/utils/PlutusScriptType.d.ts +0 -12
- package/dist/utils/PlutusScriptType.js +0 -1
- package/dist/utils/ToJson.d.ts +0 -4
- package/dist/utils/ToJson.js +0 -5
- package/dist/utils/UPLCFlatUtils/index.d.ts +0 -46
- package/dist/utils/UPLCFlatUtils/index.js +0 -124
- package/dist/utils/array/filterSortedStrArrInplace.d.ts +0 -7
- package/dist/utils/array/filterSortedStrArrInplace.js +0 -46
- package/dist/utils/array/keepSortedArrInplace.d.ts +0 -7
- package/dist/utils/array/keepSortedArrInplace.js +0 -49
- package/dist/utils/array/mergeSortedStrArrInplace.d.ts +0 -6
- package/dist/utils/array/mergeSortedStrArrInplace.js +0 -52
- package/dist/utils/assert.d.ts +0 -1
- package/dist/utils/assert.js +0 -5
- package/dist/utils/capitalize.d.ts +0 -1
- package/dist/utils/capitalize.js +0 -5
- package/dist/utils/combinators.d.ts +0 -37
- package/dist/utils/combinators.js +0 -76
- package/dist/utils/getCallStackAt/index.d.ts +0 -43
- package/dist/utils/getCallStackAt/index.js +0 -295
- package/dist/utils/hex.d.ts +0 -1
- package/dist/utils/hex.js +0 -6
- package/dist/utils/ints.d.ts +0 -4
- package/dist/utils/ints.js +0 -19
- package/dist/utils/isNonEmpty.d.ts +0 -1
- package/dist/utils/isNonEmpty.js +0 -3
- package/dist/utils/maybeData.d.ts +0 -4
- package/dist/utils/maybeData.js +0 -10
- package/dist/utils/stringify.d.ts +0 -2
- package/dist/utils/stringify.js +0 -31
- package/dist/utils/terminal.d.ts +0 -28
- package/dist/utils/terminal.js +0 -38
- package/dist/utils/text.d.ts +0 -172
- package/dist/utils/text.js +0 -672
- package/dist/utils/types.d.ts +0 -12
- package/dist/utils/types.js +0 -1
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
/*
|
|
3
|
-
export function _compileExprStmt(
|
|
4
|
-
ctx: AstCompilationCtx,
|
|
5
|
-
stmt: ExprStmt
|
|
6
|
-
): [ TirExprStmt ] | undefined
|
|
7
|
-
{
|
|
8
|
-
const expr = _compileExpr( ctx, stmt.expr, void_t );
|
|
9
|
-
if( !expr ) return undefined;
|
|
10
|
-
return [ new TirExprStmt( expr, stmt.range ) ];
|
|
11
|
-
}
|
|
12
|
-
//*/
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { FailStmt } from "../../../../ast/nodes/statements/FailStmt.js";
|
|
2
|
-
import { TirFailStmt } from "../../../tir/statements/TirFailStmt.js";
|
|
3
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
4
|
-
export declare function _compileFailStmt(ctx: AstCompilationCtx, stmt: FailStmt): [TirFailStmt] | undefined;
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
2
|
-
import { TirFailStmt } from "../../../tir/statements/TirFailStmt.js";
|
|
3
|
-
import { canAssignTo } from "../../../tir/types/utils/canAssignTo.js";
|
|
4
|
-
import { string_t } from "../../../tir/program/stdScope/stdScope.js";
|
|
5
|
-
import { _compileExpr } from "../exprs/_compileExpr.js";
|
|
6
|
-
export function _compileFailStmt(ctx, stmt) {
|
|
7
|
-
if (!ctx.functionCtx)
|
|
8
|
-
return ctx.error(DiagnosticCode.A_fail_statement_can_only_be_used_within_a_function_body, stmt.range);
|
|
9
|
-
let failMsgExpr = undefined;
|
|
10
|
-
if (stmt.value) {
|
|
11
|
-
failMsgExpr = _compileExpr(ctx, stmt.value, string_t);
|
|
12
|
-
if (!failMsgExpr)
|
|
13
|
-
return undefined;
|
|
14
|
-
if (!canAssignTo(failMsgExpr.type, string_t))
|
|
15
|
-
return ctx.error(DiagnosticCode.Type_0_is_not_assignable_to_type_1, stmt.value.range, failMsgExpr.type.toString(), string_t.toString());
|
|
16
|
-
}
|
|
17
|
-
return [new TirFailStmt(failMsgExpr, stmt.range)];
|
|
18
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { ForOfStmt } from "../../../../ast/nodes/statements/ForOfStmt.js";
|
|
2
|
-
import { TirForOfStmt } from "../../../tir/statements/TirForOfStmt.js";
|
|
3
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
4
|
-
export declare function _compileForOfStmt(ctx: AstCompilationCtx, stmt: ForOfStmt): [TirForOfStmt] | undefined;
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
2
|
-
import { TirForOfStmt } from "../../../tir/statements/TirForOfStmt.js";
|
|
3
|
-
import { TirListT } from "../../../tir/types/TirNativeType/index.js";
|
|
4
|
-
import { TirTypeParam } from "../../../tir/types/TirTypeParam.js";
|
|
5
|
-
import { canAssignTo } from "../../../tir/types/utils/canAssignTo.js";
|
|
6
|
-
import { getListTypeArg } from "../../../tir/types/utils/getListTypeArg.js";
|
|
7
|
-
import { wrapManyStatements } from "../../utils/wrapManyStatementsOrReturnSame.js";
|
|
8
|
-
import { _compileExpr } from "../exprs/_compileExpr.js";
|
|
9
|
-
import { _compileStatement } from "./_compileStatement.js";
|
|
10
|
-
import { _compileVarDecl } from "./_compileVarStmt.js";
|
|
11
|
-
export function _compileForOfStmt(ctx, stmt) {
|
|
12
|
-
const any_list_t = new TirListT(new TirTypeParam("T"));
|
|
13
|
-
const iterableExpr = _compileExpr(ctx, stmt.iterable, any_list_t);
|
|
14
|
-
if (!iterableExpr)
|
|
15
|
-
return undefined;
|
|
16
|
-
const elemsType = getListTypeArg(iterableExpr.type);
|
|
17
|
-
if (!elemsType)
|
|
18
|
-
return ctx.error(DiagnosticCode.The_argument_of_a_for_of_statement_must_be_an_iterable, stmt.iterable.range);
|
|
19
|
-
const loopCtx = ctx.newLoopChildScope();
|
|
20
|
-
const varDecl = stmt.elemDeclaration.declarations[0];
|
|
21
|
-
const tirVarDecl = _compileVarDecl(loopCtx, varDecl, elemsType);
|
|
22
|
-
if (!tirVarDecl)
|
|
23
|
-
return undefined;
|
|
24
|
-
if (!canAssignTo(tirVarDecl.type, elemsType))
|
|
25
|
-
return ctx.error(DiagnosticCode.Type_0_is_not_assignable_to_type_1, varDecl.range, tirVarDecl.type.toString(), elemsType.toString());
|
|
26
|
-
const tirBody = wrapManyStatements(_compileStatement(loopCtx, stmt.body), stmt.body.range);
|
|
27
|
-
if (!tirBody)
|
|
28
|
-
return undefined;
|
|
29
|
-
return [new TirForOfStmt(tirVarDecl, iterableExpr, tirBody, stmt.range)];
|
|
30
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { AssignmentStmt } from "../../../../ast/nodes/statements/AssignmentStmt.js";
|
|
2
|
-
import { ForStmt } from "../../../../ast/nodes/statements/ForStmt.js";
|
|
3
|
-
import { TirAssignmentStmt } from "../../../tir/statements/TirAssignmentStmt.js";
|
|
4
|
-
import { TirForStmt } from "../../../tir/statements/TirForStmt.js";
|
|
5
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
6
|
-
export declare function _compileForStmt(ctx: AstCompilationCtx, stmt: ForStmt): [TirForStmt] | undefined;
|
|
7
|
-
export declare function _compileForUpdateStmts(ctx: AstCompilationCtx, stmts: AssignmentStmt[]): TirAssignmentStmt[] | undefined;
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { TirForStmt } from "../../../tir/statements/TirForStmt.js";
|
|
2
|
-
import { bool_t } from "../../../tir/program/stdScope/stdScope.js";
|
|
3
|
-
import { wrapManyStatements } from "../../utils/wrapManyStatementsOrReturnSame.js";
|
|
4
|
-
import { _compileExpr } from "../exprs/_compileExpr.js";
|
|
5
|
-
import { _compileAssignmentStmt } from "./_compileAssignmentStmt.js";
|
|
6
|
-
import { _compileStatement } from "./_compileStatement.js";
|
|
7
|
-
import { _compileVarStmt } from "./_compileVarStmt.js";
|
|
8
|
-
import { TirSimpleVarDecl } from "../../../tir/statements/TirVarDecl/TirSimpleVarDecl.js";
|
|
9
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
10
|
-
export function _compileForStmt(ctx, stmt) {
|
|
11
|
-
const loopScope = ctx.newLoopChildScope();
|
|
12
|
-
const _tirInit = stmt.init ? _compileVarStmt(loopScope, stmt.init) : undefined;
|
|
13
|
-
if (!_tirInit)
|
|
14
|
-
return undefined;
|
|
15
|
-
const nonSimpleDecl = _tirInit.filter(s => !(s instanceof TirSimpleVarDecl));
|
|
16
|
-
if (nonSimpleDecl.length > 0) {
|
|
17
|
-
for (const decl of nonSimpleDecl) {
|
|
18
|
-
ctx.error(DiagnosticCode.for_loop_initialization_variables_cannot_be_destructured_Declare_it_as_a_simple_variable_and_move_the_destructuring_in_the_loop_body, decl.range);
|
|
19
|
-
}
|
|
20
|
-
return undefined;
|
|
21
|
-
}
|
|
22
|
-
const tirInit = _tirInit;
|
|
23
|
-
const tirCond = stmt.condition ? _compileExpr(loopScope, stmt.condition, bool_t) : undefined;
|
|
24
|
-
if (!tirCond)
|
|
25
|
-
return undefined;
|
|
26
|
-
const tirUpdates = _compileForUpdateStmts(loopScope, stmt.updates);
|
|
27
|
-
if (!tirUpdates)
|
|
28
|
-
return undefined;
|
|
29
|
-
const tirBody = wrapManyStatements(_compileStatement(loopScope.newBranchChildScope(), stmt.body), stmt.body.range);
|
|
30
|
-
if (!tirBody)
|
|
31
|
-
return undefined;
|
|
32
|
-
return [new TirForStmt(tirInit, tirCond, tirUpdates, tirBody, stmt.range)];
|
|
33
|
-
}
|
|
34
|
-
export function _compileForUpdateStmts(ctx, stmts) {
|
|
35
|
-
const tirStmts = [];
|
|
36
|
-
for (let stmt of stmts) {
|
|
37
|
-
const tirStmt = _compileAssignmentStmt(ctx, stmt);
|
|
38
|
-
// empty array here returns undefined
|
|
39
|
-
// that is fine, because an empty array of assignments
|
|
40
|
-
// is not a valid statement
|
|
41
|
-
if (!tirStmt)
|
|
42
|
-
return undefined;
|
|
43
|
-
tirStmts.push(...tirStmt);
|
|
44
|
-
}
|
|
45
|
-
return tirStmts;
|
|
46
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { IfStmt } from "../../../../ast/nodes/statements/IfStmt.js";
|
|
2
|
-
import { TirIfStmt } from "../../../tir/statements/TirIfStmt.js";
|
|
3
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
4
|
-
export declare function _compileIfStmt(ctx: AstCompilationCtx, stmt: IfStmt): [TirIfStmt] | undefined;
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
2
|
-
import { TirIfStmt } from "../../../tir/statements/TirIfStmt.js";
|
|
3
|
-
import { canAssignTo, canAssignToOptional } from "../../../tir/types/utils/canAssignTo.js";
|
|
4
|
-
import { bool_t } from "../../../tir/program/stdScope/stdScope.js";
|
|
5
|
-
import { wrapManyStatements } from "../../utils/wrapManyStatementsOrReturnSame.js";
|
|
6
|
-
import { _compileExpr } from "../exprs/_compileExpr.js";
|
|
7
|
-
import { _compileStatement } from "./_compileStatement.js";
|
|
8
|
-
export function _compileIfStmt(ctx, stmt) {
|
|
9
|
-
const coditionExpr = _compileExpr(ctx, stmt.condition, bool_t);
|
|
10
|
-
if (!coditionExpr)
|
|
11
|
-
return undefined;
|
|
12
|
-
if (!canAssignTo(coditionExpr.type, bool_t)
|
|
13
|
-
&& !canAssignToOptional(coditionExpr.type))
|
|
14
|
-
return ctx.error(DiagnosticCode.Type_0_is_not_assignable_to_type_1, stmt.condition.range, coditionExpr.type.toString(), "boolean | Optional<T>");
|
|
15
|
-
const thenBranch = wrapManyStatements(_compileStatement(ctx.newBranchChildScope(), stmt.thenBranch), stmt.thenBranch.range);
|
|
16
|
-
if (!thenBranch)
|
|
17
|
-
return undefined;
|
|
18
|
-
let elseBranch = undefined;
|
|
19
|
-
if (stmt.elseBranch) {
|
|
20
|
-
elseBranch = wrapManyStatements(_compileStatement(ctx.newBranchChildScope(), stmt.elseBranch), stmt.elseBranch.range);
|
|
21
|
-
if (!elseBranch)
|
|
22
|
-
return undefined;
|
|
23
|
-
}
|
|
24
|
-
return [
|
|
25
|
-
new TirIfStmt(coditionExpr, thenBranch, elseBranch, stmt.range)
|
|
26
|
-
];
|
|
27
|
-
}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { MatchStmt, MatchStmtCase } from "../../../../ast/nodes/statements/MatchStmt.js";
|
|
2
|
-
import { TirMatchStmt, TirMatchStmtCase, TirMatchStmtWildcardCase } from "../../../tir/statements/TirMatchStmt.js";
|
|
3
|
-
import { DeconstructableTirType } from "../../../tir/types/utils/getDeconstructableType.js";
|
|
4
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
5
|
-
export declare function _compileMatchStmt(ctx: AstCompilationCtx, stmt: MatchStmt): [TirMatchStmt] | undefined;
|
|
6
|
-
export declare function _compileTirMatchStmtCase(ctx: AstCompilationCtx, matchCase: MatchStmtCase, deconstructableType: DeconstructableTirType, constrNamesAlreadySpecified: string[]): TirMatchStmtCase | TirMatchStmtWildcardCase | undefined;
|
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
import { ArrayLikeDeconstr } from "../../../../ast/nodes/statements/declarations/VarDecl/ArrayLikeDeconstr.js";
|
|
2
|
-
import { NamedDeconstructVarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/NamedDeconstructVarDecl.js";
|
|
3
|
-
import { SimpleVarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/SimpleVarDecl.js";
|
|
4
|
-
import { SingleDeconstructVarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/SingleDeconstructVarDecl.js";
|
|
5
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
6
|
-
import { TirMatchStmt, TirMatchStmtCase, TirMatchStmtWildcardCase } from "../../../tir/statements/TirMatchStmt.js";
|
|
7
|
-
import { TirNamedDeconstructVarDecl } from "../../../tir/statements/TirVarDecl/TirNamedDeconstructVarDecl.js";
|
|
8
|
-
import { TirDataT } from "../../../tir/types/TirNativeType/native/data.js";
|
|
9
|
-
import { TirDataOptT } from "../../../tir/types/TirNativeType/native/Optional/data.js";
|
|
10
|
-
import { TirSopOptT } from "../../../tir/types/TirNativeType/native/Optional/sop.js";
|
|
11
|
-
import { isTirStructType, TirDataStructType, TirSoPStructType } from "../../../tir/types/TirStructType.js";
|
|
12
|
-
import { getDeconstructableType } from "../../../tir/types/utils/getDeconstructableType.js";
|
|
13
|
-
import { wrapManyStatements } from "../../utils/wrapManyStatementsOrReturnSame.js";
|
|
14
|
-
import { _compileExpr } from "../exprs/_compileExpr.js";
|
|
15
|
-
import { _compileStatement } from "./_compileStatement.js";
|
|
16
|
-
import { _compileNamedDeconstructVarDecl, _compileSingleDeconstructVarDecl, _compileVarDecl } from "./_compileVarStmt.js";
|
|
17
|
-
export function _compileMatchStmt(ctx, stmt) {
|
|
18
|
-
if (!ctx.functionCtx)
|
|
19
|
-
return ctx.error(DiagnosticCode.A_match_statement_can_only_be_used_within_a_function_body, stmt.range);
|
|
20
|
-
const matchExpr = _compileExpr(ctx, stmt.matchExpr, undefined);
|
|
21
|
-
if (!matchExpr)
|
|
22
|
-
return undefined;
|
|
23
|
-
const matchExprType = matchExpr.type;
|
|
24
|
-
const deconstructableType = getDeconstructableType(matchExprType);
|
|
25
|
-
if (!deconstructableType)
|
|
26
|
-
return ctx.error(DiagnosticCode.A_value_of_type_0_cannot_be_deconstructed, stmt.matchExpr.range, matchExprType.toString());
|
|
27
|
-
// TODO: add support for all deconstructable types
|
|
28
|
-
if (!isTirStructType(deconstructableType)) {
|
|
29
|
-
return ctx.error(DiagnosticCode.Not_implemented_0, stmt.matchExpr.range, "only structs supported for now, sorry!");
|
|
30
|
-
}
|
|
31
|
-
const ctors = deconstructableType.constructors;
|
|
32
|
-
const ctorNames = ctors.map(c => c.name);
|
|
33
|
-
const missingCtors = ctorNames.slice();
|
|
34
|
-
if (stmt.cases.length === 0)
|
|
35
|
-
return ctx.error(DiagnosticCode.A_match_statement_must_have_at_least_one_case, stmt.range);
|
|
36
|
-
const cases = [];
|
|
37
|
-
let wildcardCase = undefined;
|
|
38
|
-
const constrNamesAlreadySpecified = [];
|
|
39
|
-
for (const matchCase of stmt.cases) {
|
|
40
|
-
const branch = _compileTirMatchStmtCase(ctx, matchCase, deconstructableType, constrNamesAlreadySpecified);
|
|
41
|
-
if (!branch)
|
|
42
|
-
return undefined;
|
|
43
|
-
if (branch instanceof TirMatchStmtWildcardCase) {
|
|
44
|
-
wildcardCase = branch;
|
|
45
|
-
break; // wildcard case catches any branch specified after it
|
|
46
|
-
}
|
|
47
|
-
const indexOfCtor = missingCtors.indexOf(branch.pattern.constrName);
|
|
48
|
-
if (indexOfCtor === -1) {
|
|
49
|
-
return ctx.error(DiagnosticCode.Unknown_0_constructor_1, branch.pattern.range, deconstructableType.toString(), branch.pattern.constrName);
|
|
50
|
-
}
|
|
51
|
-
missingCtors.splice(indexOfCtor, 1);
|
|
52
|
-
cases.push(branch);
|
|
53
|
-
}
|
|
54
|
-
if (!wildcardCase && cases.length < ctors.length) {
|
|
55
|
-
return ctx.error(DiagnosticCode.Match_cases_are_not_exhaustive, stmt.range);
|
|
56
|
-
}
|
|
57
|
-
return [new TirMatchStmt(matchExpr, cases, wildcardCase, stmt.range)];
|
|
58
|
-
}
|
|
59
|
-
export function _compileTirMatchStmtCase(ctx, matchCase, deconstructableType, constrNamesAlreadySpecified) {
|
|
60
|
-
const pattern = _compileVarDecl(ctx, matchCase.pattern, deconstructableType);
|
|
61
|
-
if (!pattern)
|
|
62
|
-
return undefined;
|
|
63
|
-
if (pattern instanceof SimpleVarDecl) {
|
|
64
|
-
if (pattern.name.text === "_") {
|
|
65
|
-
const branchCtx = ctx.newBranchChildScope();
|
|
66
|
-
const branchBody = wrapManyStatements(_compileStatement(branchCtx, matchCase.body), matchCase.body.range);
|
|
67
|
-
if (!branchBody)
|
|
68
|
-
return undefined;
|
|
69
|
-
return new TirMatchStmtWildcardCase(branchBody, matchCase.range);
|
|
70
|
-
}
|
|
71
|
-
return ctx.error(DiagnosticCode.The_argument_of_a_match_statement_branch_must_be_deconstructed, matchCase.pattern.range);
|
|
72
|
-
}
|
|
73
|
-
else if (pattern instanceof NamedDeconstructVarDecl) {
|
|
74
|
-
const deconstructedCtorIdentifier = pattern.name;
|
|
75
|
-
const deconstructedCtorName = deconstructedCtorIdentifier.text;
|
|
76
|
-
if (constrNamesAlreadySpecified.includes(deconstructedCtorName))
|
|
77
|
-
return ctx.error(DiagnosticCode.Constructor_0_was_already_specified, deconstructedCtorIdentifier.range, deconstructedCtorName);
|
|
78
|
-
constrNamesAlreadySpecified.push(deconstructedCtorName);
|
|
79
|
-
if (deconstructableType instanceof TirDataT) {
|
|
80
|
-
if (!(deconstructedCtorName === "Constr" // { index, fields, ...rest }
|
|
81
|
-
|| deconstructedCtorName === "Map" // { map, ...rest }
|
|
82
|
-
|| deconstructedCtorName === "List" // { list, ...rest }
|
|
83
|
-
|| deconstructedCtorName === "B" // { bytes, ...rest }
|
|
84
|
-
|| deconstructedCtorName === "I" // { int, ...rest }
|
|
85
|
-
))
|
|
86
|
-
return ctx.error(DiagnosticCode.Unknown_0_constructor_1, pattern.name.range, "data", deconstructedCtorName);
|
|
87
|
-
const branchCtx = ctx.newBranchChildScope();
|
|
88
|
-
const branchArg = _compileNamedDeconstructVarDecl(branchCtx, pattern, deconstructableType);
|
|
89
|
-
if (!branchArg)
|
|
90
|
-
return undefined;
|
|
91
|
-
const branchBody = wrapManyStatements(_compileStatement(branchCtx, matchCase.body), matchCase.body.range);
|
|
92
|
-
if (!branchBody)
|
|
93
|
-
return undefined;
|
|
94
|
-
return new TirMatchStmtCase(branchArg, branchBody, matchCase.range);
|
|
95
|
-
}
|
|
96
|
-
else if (deconstructableType instanceof TirSopOptT
|
|
97
|
-
|| deconstructableType instanceof TirDataOptT) {
|
|
98
|
-
if (!(deconstructedCtorName === "Some" // { value, ...rest }
|
|
99
|
-
|| deconstructedCtorName === "None" // { ...rest }
|
|
100
|
-
))
|
|
101
|
-
return ctx.error(DiagnosticCode.Unknown_0_constructor_1, pattern.name.range, "Optional", deconstructedCtorName);
|
|
102
|
-
const branchCtx = ctx.newBranchChildScope();
|
|
103
|
-
const branchArg = _compileNamedDeconstructVarDecl(branchCtx, pattern, deconstructableType);
|
|
104
|
-
if (!branchArg)
|
|
105
|
-
return undefined;
|
|
106
|
-
const branchBody = wrapManyStatements(_compileStatement(branchCtx, matchCase.body), matchCase.body.range);
|
|
107
|
-
if (!branchBody)
|
|
108
|
-
return undefined;
|
|
109
|
-
return new TirMatchStmtCase(branchArg, branchBody, matchCase.range);
|
|
110
|
-
}
|
|
111
|
-
else if (deconstructableType instanceof TirSoPStructType
|
|
112
|
-
|| deconstructableType instanceof TirDataStructType) {
|
|
113
|
-
const ctorDef = deconstructableType.constructors.find(c => c.name === deconstructedCtorName);
|
|
114
|
-
if (!ctorDef)
|
|
115
|
-
return ctx.error(DiagnosticCode.Unknown_0_constructor_1, pattern.name.range, deconstructableType.toString(), deconstructedCtorName);
|
|
116
|
-
const branchCtx = ctx.newBranchChildScope();
|
|
117
|
-
const branchArg = _compileNamedDeconstructVarDecl(branchCtx, pattern, deconstructableType);
|
|
118
|
-
if (!branchArg)
|
|
119
|
-
return undefined;
|
|
120
|
-
const branchBody = wrapManyStatements(_compileStatement(branchCtx, matchCase.body), matchCase.body.range);
|
|
121
|
-
if (!branchBody)
|
|
122
|
-
return undefined;
|
|
123
|
-
return new TirMatchStmtCase(branchArg, branchBody, matchCase.range);
|
|
124
|
-
}
|
|
125
|
-
// else if( deconstructableType instanceof TirListT )
|
|
126
|
-
// else if( deconstructableType instanceof TirLinearMapT )
|
|
127
|
-
else
|
|
128
|
-
return ctx.error(DiagnosticCode.A_value_of_type_0_cannot_be_deconstructed_by_named_object, matchCase.pattern.range, deconstructableType.toString());
|
|
129
|
-
}
|
|
130
|
-
else if (pattern instanceof SingleDeconstructVarDecl) {
|
|
131
|
-
if (!isTirStructType(deconstructableType))
|
|
132
|
-
return ctx.error(DiagnosticCode.A_value_of_type_0_cannot_be_deconstructed_as_unnamed_object, matchCase.pattern.range, deconstructableType.toString());
|
|
133
|
-
if (deconstructableType.constructors.length !== 1)
|
|
134
|
-
return ctx.error(DiagnosticCode.A_value_of_type_0_has_multiple_constructors, matchCase.pattern.range, deconstructableType.toString());
|
|
135
|
-
const branchCtx = ctx.newBranchChildScope();
|
|
136
|
-
const branchArg = _compileSingleDeconstructVarDecl(branchCtx, pattern, deconstructableType);
|
|
137
|
-
if (!branchArg)
|
|
138
|
-
return undefined;
|
|
139
|
-
if (!(branchArg instanceof TirNamedDeconstructVarDecl)) {
|
|
140
|
-
return ctx.error(DiagnosticCode.Not_implemented_0, matchCase.pattern.range, "only structs supported for now, sorry!");
|
|
141
|
-
}
|
|
142
|
-
const branchBody = wrapManyStatements(_compileStatement(branchCtx, matchCase.body), matchCase.body.range);
|
|
143
|
-
if (!branchBody)
|
|
144
|
-
return undefined;
|
|
145
|
-
return new TirMatchStmtCase(branchArg, branchBody, matchCase.range);
|
|
146
|
-
}
|
|
147
|
-
else if (pattern instanceof ArrayLikeDeconstr) {
|
|
148
|
-
return ctx.error(DiagnosticCode.Not_implemented_0, pattern.range, "only structs supported for now, sorry!");
|
|
149
|
-
/*
|
|
150
|
-
if(!(
|
|
151
|
-
deconstructableType instanceof TirListT
|
|
152
|
-
|| deconstructableType instanceof TirLinearMapT
|
|
153
|
-
)) return ctx.error(
|
|
154
|
-
DiagnosticCode.A_value_of_type_0_cannot_be_deconstructed_as_an_array,
|
|
155
|
-
matchCase.pattern.range, deconstructableType.toString()
|
|
156
|
-
);
|
|
157
|
-
|
|
158
|
-
const branchCtx = ctx.newBranchChildScope();
|
|
159
|
-
|
|
160
|
-
const branchArg = _compileArrayLikeDeconstr(
|
|
161
|
-
branchCtx,
|
|
162
|
-
pattern,
|
|
163
|
-
deconstructableType
|
|
164
|
-
);
|
|
165
|
-
if( !branchArg ) return undefined;
|
|
166
|
-
const branchBody = wrapManyStatements(
|
|
167
|
-
_compileStatement(
|
|
168
|
-
branchCtx,
|
|
169
|
-
matchCase.body
|
|
170
|
-
),
|
|
171
|
-
matchCase.body.range
|
|
172
|
-
);
|
|
173
|
-
if( !branchBody ) return undefined;
|
|
174
|
-
|
|
175
|
-
return new TirMatchStmtCase(
|
|
176
|
-
branchArg,
|
|
177
|
-
branchBody,
|
|
178
|
-
matchCase.range
|
|
179
|
-
);
|
|
180
|
-
//*/
|
|
181
|
-
}
|
|
182
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { ReturnStmt } from "../../../../ast/nodes/statements/ReturnStmt.js";
|
|
2
|
-
import { TirReturnStmt } from "../../../tir/statements/TirReturnStmt.js";
|
|
3
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
4
|
-
export declare function _compileReturnStmt(ctx: AstCompilationCtx, stmt: ReturnStmt): [TirReturnStmt] | undefined;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
2
|
-
import { TirLitVoidExpr } from "../../../tir/expressions/litteral/TirLitVoidExpr.js";
|
|
3
|
-
import { TirReturnStmt } from "../../../tir/statements/TirReturnStmt.js";
|
|
4
|
-
import { canAssignTo } from "../../../tir/types/utils/canAssignTo.js";
|
|
5
|
-
import { _compileExpr } from "../exprs/_compileExpr.js";
|
|
6
|
-
export function _compileReturnStmt(ctx, stmt) {
|
|
7
|
-
if (!ctx.functionCtx)
|
|
8
|
-
return ctx.error(DiagnosticCode.A_return_statement_can_only_be_used_within_a_function_body, stmt.range);
|
|
9
|
-
const hintReturn = ctx.functionCtx.returnType;
|
|
10
|
-
const expr = stmt.value ?
|
|
11
|
-
_compileExpr(ctx, stmt.value, hintReturn) : new TirLitVoidExpr(stmt.range);
|
|
12
|
-
if (!expr)
|
|
13
|
-
return undefined;
|
|
14
|
-
if (!canAssignTo(expr.type, hintReturn))
|
|
15
|
-
return ctx.error(DiagnosticCode.Type_0_is_not_assignable_to_type_1, stmt.value?.range ?? stmt.range, expr.type.toString(), hintReturn.toString());
|
|
16
|
-
return [new TirReturnStmt(expr, stmt.range)];
|
|
17
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { BodyStmt } from "../../../../ast/nodes/statements/PebbleStmt.js";
|
|
2
|
-
import { TirStmt } from "../../../tir/statements/TirStmt.js";
|
|
3
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
4
|
-
/**
|
|
5
|
-
* here we just translate to TIR
|
|
6
|
-
*
|
|
7
|
-
* WE DO NOT OPTIMIZE
|
|
8
|
-
*
|
|
9
|
-
* optimizaitons are part of the TIR -> TermIR compilation
|
|
10
|
-
**/
|
|
11
|
-
export declare function _compileStatement(ctx: AstCompilationCtx, stmt: BodyStmt): TirStmt[] | undefined;
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
import { AssertStmt } from "../../../../ast/nodes/statements/AssertStmt.js";
|
|
2
|
-
import { isAssignmentStmt } from "../../../../ast/nodes/statements/AssignmentStmt.js";
|
|
3
|
-
import { BlockStmt } from "../../../../ast/nodes/statements/BlockStmt.js";
|
|
4
|
-
import { BreakStmt } from "../../../../ast/nodes/statements/BreakStmt.js";
|
|
5
|
-
import { ContinueStmt } from "../../../../ast/nodes/statements/ContinueStmt.js";
|
|
6
|
-
import { EmptyStmt } from "../../../../ast/nodes/statements/EmptyStmt.js";
|
|
7
|
-
import { FailStmt } from "../../../../ast/nodes/statements/FailStmt.js";
|
|
8
|
-
import { ForOfStmt } from "../../../../ast/nodes/statements/ForOfStmt.js";
|
|
9
|
-
import { ForStmt } from "../../../../ast/nodes/statements/ForStmt.js";
|
|
10
|
-
import { IfStmt } from "../../../../ast/nodes/statements/IfStmt.js";
|
|
11
|
-
import { MatchStmt } from "../../../../ast/nodes/statements/MatchStmt.js";
|
|
12
|
-
import { ReturnStmt } from "../../../../ast/nodes/statements/ReturnStmt.js";
|
|
13
|
-
import { UsingStmt } from "../../../../ast/nodes/statements/UsingStmt.js";
|
|
14
|
-
import { VarStmt } from "../../../../ast/nodes/statements/VarStmt.js";
|
|
15
|
-
import { WhileStmt } from "../../../../ast/nodes/statements/WhileStmt.js";
|
|
16
|
-
import { _compileAssertStmt } from "./_compileAssertStmt.js";
|
|
17
|
-
import { _compileAssignmentStmt } from "./_compileAssignmentStmt.js";
|
|
18
|
-
import { _compileBlockStmt } from "./_compileBlockStmt.js";
|
|
19
|
-
import { _compileBreakStmt } from "./_compileBreakStmt.js";
|
|
20
|
-
import { _compileContinueStmt } from "./_compileContinueStmt.js";
|
|
21
|
-
import { _compileFailStmt } from "./_compileFailStmt.js";
|
|
22
|
-
import { _compileForOfStmt } from "./_compileForOfStmt.js";
|
|
23
|
-
import { _compileForStmt } from "./_compileForStmt.js";
|
|
24
|
-
import { _compileIfStmt } from "./_compileIfStmt.js";
|
|
25
|
-
import { _compileMatchStmt } from "./_compileMatchStmt.js";
|
|
26
|
-
import { _compileReturnStmt } from "./_compileReturnStmt.js";
|
|
27
|
-
import { _compileUsingStmt } from "./_compileUsingStmt.js";
|
|
28
|
-
import { _compileVarStmt } from "./_compileVarStmt.js";
|
|
29
|
-
import { _compileWhileStmt } from "./_compileWhileStmt.js";
|
|
30
|
-
/**
|
|
31
|
-
* here we just translate to TIR
|
|
32
|
-
*
|
|
33
|
-
* WE DO NOT OPTIMIZE
|
|
34
|
-
*
|
|
35
|
-
* optimizaitons are part of the TIR -> TermIR compilation
|
|
36
|
-
**/
|
|
37
|
-
export function _compileStatement(ctx, stmt) {
|
|
38
|
-
if (stmt instanceof IfStmt)
|
|
39
|
-
return _compileIfStmt(ctx, stmt);
|
|
40
|
-
if (stmt instanceof VarStmt)
|
|
41
|
-
return _compileVarStmt(ctx, stmt);
|
|
42
|
-
if (stmt instanceof ForStmt)
|
|
43
|
-
return _compileForStmt(ctx, stmt);
|
|
44
|
-
if (stmt instanceof ForOfStmt)
|
|
45
|
-
return _compileForOfStmt(ctx, stmt);
|
|
46
|
-
if (stmt instanceof WhileStmt)
|
|
47
|
-
return _compileWhileStmt(ctx, stmt);
|
|
48
|
-
if (stmt instanceof ReturnStmt)
|
|
49
|
-
return _compileReturnStmt(ctx, stmt);
|
|
50
|
-
if (stmt instanceof BlockStmt)
|
|
51
|
-
return _compileBlockStmt(ctx, stmt);
|
|
52
|
-
if (stmt instanceof BreakStmt)
|
|
53
|
-
return _compileBreakStmt(ctx, stmt);
|
|
54
|
-
if (stmt instanceof ContinueStmt)
|
|
55
|
-
return _compileContinueStmt(ctx, stmt);
|
|
56
|
-
if (stmt instanceof EmptyStmt)
|
|
57
|
-
return [];
|
|
58
|
-
if (stmt instanceof FailStmt)
|
|
59
|
-
return _compileFailStmt(ctx, stmt);
|
|
60
|
-
if (stmt instanceof AssertStmt)
|
|
61
|
-
return _compileAssertStmt(ctx, stmt);
|
|
62
|
-
// if( stmt instanceof TestStmt ) return _compileTestStmt( ctx, stmt );
|
|
63
|
-
if (stmt instanceof MatchStmt)
|
|
64
|
-
return _compileMatchStmt(ctx, stmt);
|
|
65
|
-
if (isAssignmentStmt(stmt))
|
|
66
|
-
return _compileAssignmentStmt(ctx, stmt);
|
|
67
|
-
// if( stmt instanceof ExprStmt ) return _compileExprStmt( ctx, stmt );
|
|
68
|
-
if (stmt instanceof UsingStmt)
|
|
69
|
-
return _compileUsingStmt(ctx, stmt);
|
|
70
|
-
const tsEnsureExsautstiveCheck = stmt;
|
|
71
|
-
console.error(stmt);
|
|
72
|
-
throw new Error("unreachable::AstCompiler::_compileStatement");
|
|
73
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
/*
|
|
3
|
-
export function _compileTestStmt(
|
|
4
|
-
ctx: AstCompilationCtx,
|
|
5
|
-
stmt: TestStmt
|
|
6
|
-
): [ TirTestStmt ] | undefined
|
|
7
|
-
{
|
|
8
|
-
if( ctx.functionCtx ) return ctx.error(
|
|
9
|
-
DiagnosticCode.A_test_statement_can_only_be_used_outside_a_function,
|
|
10
|
-
stmt.range
|
|
11
|
-
);
|
|
12
|
-
|
|
13
|
-
let tirBody = wrapManyStatements(
|
|
14
|
-
_compileStatement(
|
|
15
|
-
ctx.newBranchChildScope(),
|
|
16
|
-
stmt.body
|
|
17
|
-
),
|
|
18
|
-
stmt.body.range
|
|
19
|
-
);
|
|
20
|
-
if( !tirBody ) return undefined;
|
|
21
|
-
if(!( tirBody instanceof TirBlockStmt))
|
|
22
|
-
{
|
|
23
|
-
tirBody = new TirBlockStmt( [ tirBody ], stmt.body.range );
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return [ new TirTestStmt(
|
|
27
|
-
stmt.testName?.string,
|
|
28
|
-
tirBody as TirBlockStmt,
|
|
29
|
-
stmt.range
|
|
30
|
-
) ];
|
|
31
|
-
}
|
|
32
|
-
//*/
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { UsingStmt } from "../../../../ast/nodes/statements/UsingStmt.js";
|
|
2
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
3
|
-
/**
|
|
4
|
-
* `using` only introduces symbols in scope
|
|
5
|
-
*
|
|
6
|
-
* we don't represent `using` statements in the TIR
|
|
7
|
-
*
|
|
8
|
-
* @returns {[]} an empty array if successful compilation
|
|
9
|
-
* @returns {undefined} `undefined` if compilation failed
|
|
10
|
-
**/
|
|
11
|
-
export declare function _compileUsingStmt(ctx: AstCompilationCtx, stmt: UsingStmt): [] | undefined;
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { DiagnosticCode } from "../../../../diagnostics/diagnosticMessages.generated.js";
|
|
2
|
-
import { getStructType } from "../../../tir/types/utils/canAssignTo.js";
|
|
3
|
-
import { _compileDataEncodedConcreteType } from "../types/_compileDataEncodedConcreteType.js";
|
|
4
|
-
import { _compileSopEncodedConcreteType } from "../types/_compileSopEncodedConcreteType.js";
|
|
5
|
-
/**
|
|
6
|
-
* `using` only introduces symbols in scope
|
|
7
|
-
*
|
|
8
|
-
* we don't represent `using` statements in the TIR
|
|
9
|
-
*
|
|
10
|
-
* @returns {[]} an empty array if successful compilation
|
|
11
|
-
* @returns {undefined} `undefined` if compilation failed
|
|
12
|
-
**/
|
|
13
|
-
export function _compileUsingStmt(ctx, stmt) {
|
|
14
|
-
stmt.constructorNames;
|
|
15
|
-
stmt.structTypeExpr;
|
|
16
|
-
stmt.range;
|
|
17
|
-
const structOrAliasType = (_compileSopEncodedConcreteType(ctx, stmt.structTypeExpr)
|
|
18
|
-
?? _compileDataEncodedConcreteType(ctx, stmt.structTypeExpr));
|
|
19
|
-
if (!structOrAliasType)
|
|
20
|
-
return undefined;
|
|
21
|
-
// un-alias
|
|
22
|
-
const structType = getStructType(structOrAliasType);
|
|
23
|
-
if (!structType || !structType.isConcrete())
|
|
24
|
-
return ctx.error(DiagnosticCode.Type_0_does_not_have_constructors, stmt.structTypeExpr.range, structOrAliasType.toString());
|
|
25
|
-
const defCtorNames = structType.constructors.map(c => c.name);
|
|
26
|
-
const sameStmtCtorNames = [];
|
|
27
|
-
for (const stmtCtor of stmt.constructorNames) {
|
|
28
|
-
const stmtCtorNameId = stmtCtor.constructorName;
|
|
29
|
-
const stmtCtorName = stmtCtorNameId.text;
|
|
30
|
-
const stmtReassignedCtorName = stmtCtor.renamedConstructorName;
|
|
31
|
-
if (!defCtorNames.includes(stmtCtorName))
|
|
32
|
-
return ctx.error(DiagnosticCode.Constructor_0_is_not_part_of_the_definition_of_1, stmtCtorNameId.range, stmtCtorName, structType.toString());
|
|
33
|
-
if (sameStmtCtorNames.includes(stmtCtorName))
|
|
34
|
-
return ctx.error(DiagnosticCode.Constructor_0_was_already_specified, stmtCtorNameId.range, stmtCtorName);
|
|
35
|
-
sameStmtCtorNames.push(stmtCtorName);
|
|
36
|
-
const valid = ctx.scope.defineAviableConstructorIfValid(stmtReassignedCtorName?.text ?? stmtCtorName, stmtCtorName, structOrAliasType);
|
|
37
|
-
if (!valid)
|
|
38
|
-
return ctx.error(DiagnosticCode.Constructor_name_0_is_already_declared_in_this_scope, stmtCtorNameId.range, stmtCtorName);
|
|
39
|
-
}
|
|
40
|
-
return [];
|
|
41
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { PebbleExpr } from "../../../../ast/nodes/expr/PebbleExpr.js";
|
|
2
|
-
import { ArrayLikeDeconstr } from "../../../../ast/nodes/statements/declarations/VarDecl/ArrayLikeDeconstr.js";
|
|
3
|
-
import { NamedDeconstructVarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/NamedDeconstructVarDecl.js";
|
|
4
|
-
import { SimpleVarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/SimpleVarDecl.js";
|
|
5
|
-
import { SingleDeconstructVarDecl, ISingleDeconstructVarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/SingleDeconstructVarDecl.js";
|
|
6
|
-
import { VarDecl } from "../../../../ast/nodes/statements/declarations/VarDecl/VarDecl.js";
|
|
7
|
-
import { VarStmt } from "../../../../ast/nodes/statements/VarStmt.js";
|
|
8
|
-
import { AstTypeExpr } from "../../../../ast/nodes/types/AstTypeExpr.js";
|
|
9
|
-
import { SourceRange } from "../../../../ast/Source/SourceRange.js";
|
|
10
|
-
import { TirExpr } from "../../../tir/expressions/TirExpr.js";
|
|
11
|
-
import { TirArrayLikeDeconstr } from "../../../tir/statements/TirVarDecl/TirArrayLikeDeconstr.js";
|
|
12
|
-
import { TirNamedDeconstructVarDecl } from "../../../tir/statements/TirVarDecl/TirNamedDeconstructVarDecl.js";
|
|
13
|
-
import { TirVarDecl } from "../../../tir/statements/TirVarDecl/TirVarDecl.js";
|
|
14
|
-
import { TirStructConstr } from "../../../tir/types/TirStructType.js";
|
|
15
|
-
import { TirType } from "../../../tir/types/TirType.js";
|
|
16
|
-
import { AstCompilationCtx } from "../../AstCompilationCtx.js";
|
|
17
|
-
export declare function _compileVarStmt(ctx: AstCompilationCtx, stmt: VarStmt): TirVarDecl[] | undefined;
|
|
18
|
-
export declare function _compileVarDecl(ctx: AstCompilationCtx, decl: VarDecl, typeHint: TirType | undefined): TirVarDecl | undefined;
|
|
19
|
-
export declare function _compileSimpleVarDecl(ctx: AstCompilationCtx, decl: SimpleVarDecl, typeHint: TirType | undefined): TirVarDecl | undefined;
|
|
20
|
-
export declare function _compileNamedDeconstructVarDecl(ctx: AstCompilationCtx, decl: NamedDeconstructVarDecl, typeHint: TirType | undefined): TirNamedDeconstructVarDecl | undefined;
|
|
21
|
-
export declare function _compileSingleDeconstructVarDecl(ctx: AstCompilationCtx, decl: SingleDeconstructVarDecl, typeHint: TirType | undefined): TirVarDecl | undefined;
|
|
22
|
-
export declare function _compileArrayLikeDeconstr(ctx: AstCompilationCtx, decl: ArrayLikeDeconstr, typeHint: TirType | undefined): TirArrayLikeDeconstr | undefined;
|
|
23
|
-
export declare function _getDeconstructedFields(ctx: AstCompilationCtx, astDeconstruct: ISingleDeconstructVarDecl, ctorDef: TirStructConstr): [
|
|
24
|
-
fields: Map<string, TirVarDecl>,
|
|
25
|
-
rest: string | undefined
|
|
26
|
-
] | undefined;
|
|
27
|
-
export declare function _getVarDeclTypeAndExpr(ctx: AstCompilationCtx, decl: {
|
|
28
|
-
type: AstTypeExpr | undefined;
|
|
29
|
-
initExpr: PebbleExpr | undefined;
|
|
30
|
-
range: SourceRange;
|
|
31
|
-
}, deconstructTypeHint: TirType | undefined): [
|
|
32
|
-
varType: TirType,
|
|
33
|
-
varInitExpr: TirExpr | undefined
|
|
34
|
-
] | undefined;
|